降低数据库存储空间(通过二进制转十进制)

在开发过程中,我们一定遇到过这样的需求,前端有一个独立的开关, 将此项置为on或off, 后端我们通过1来表示"on" ,0来表示 "off" ,比如一个学生选修的课程 : 英语 on 法语 off 俄语 on 意大利语 on 日本语 off 我们在后端可以通过 Integer类型的 英语1法语0俄语1意大利语1日本语0来表示。如何需要单独的在数据库中建立五个列表示这五种语言,那就太浪费内存了 我们可以通过用以下方法来节省内存:

(1) 首先分析问题: 字段只有0和1 像极了二进制的表示方法,我们尝试将该学生选修的内容有10110来表示,然后不足八位数 用0来补齐 结果就是 00010110 ,此数不正是二进制的表示法,代表十进制为22, 我们直接可以在数据库存一个字段代表学科 结果为22

(2) 查询该字段的时候 我们需要将这个字段的十进制表示法转换为二进制表示法, 22转二进制不就是00010110,然后根据某个位置对应的数字代表的内容 直接返回给前端就好了,这样直接节省了4个字段存储的空间,在MySQL数据库中,一个int类型的字段占用4个字节,也就是一条记录就节省了16个字节,效果非常明显。

关于用到的方法我也非常贴心的给大家整理出来了,大家直接复制到你们的工具类用就可以了

    /**
     * 按位取值,返回指定位的值
     *
     * @param value 十进制值
     * @param bit   指定位序号,从1开始
     * @return 指定位序号值
     */
    public static int getBinaryIndex(final Long value, final int bit) {
        return (int) (value >> (bit - 1) & 1);
    }

    /**
     * 设置二进制值
     *
     * @param value 十进制值
     * @param bit   指定位序号,从1开始
     * @param index 0或1
     * @return 十进制值
     */
    public static Long setBinaryIndex(Long value, int bit, int index) {
        if (getBinaryIndex(value, bit) == 1) {
            if (index == 0) {
                value = value - (1L << bit - 1);
            }
        } else {
            if (index == 1) {
                value = value | (1L << bit - 1);
            }
        }
        return value;
    }

方法测试: 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值