mysql存储比特位

一、介绍

二、SQL

CREATE TABLE bits_table (id INT PRIMARY KEY AUTO_INCREMENT,bit_value BIGINT UNSIGNED
);-- 插入一个 8 位的 BIT 值
INSERT INTO bits_table (bit_value) VALUES (B'10101010');-- 查询并格式化输出
SELECT id,bit_value,CONCAT('b', LPAD(BIN(bit_value), 64, '0')) AS formatted_bit_value -- 将 BIGINT 转换为 64 位的二进制字符串
FROM bits_table;

在这个例子中,CONCAT('b', LPAD(BIN(bit_value), 64, '0')) 用于将 bit_value 转换为一个以 'b' 开头的 64 位二进制字符串,LPAD 用于在左边填充 '0' 以达到 64 位的长度。

请注意,如果你需要存储非整数数量的位或者位数不固定,你可能需要以文本形式存储或者使用其他数据库特性来实现。

-- 假设我们有一个表 `bits_table`,其中有一个 `BIGINT` 类型的列 `bigint_col`
-- 我们要修改 `bigint_col` 列的第二位-- 将 `bigint` 转换为 `bit` 字符串,并取得第二位的值
SELECT bigint_col,-- 将 `bigint` 转换为 `bit` 字符串,并取得第二位的值SUBSTRING(BIN(bigint_col), 2, 1) AS second_bit
FROMbits_table;-- 更新第二位为1
UPDATE bits_table
SET bigint_col = -- 将 `bigint` 转换为 `bit` 字符串,将第二位设置为1,然后转换回 `bigint`(CONV(CONCAT(SUBSTRING(BIN(bigint_col), 1, 1), '1', SUBSTRING(BIN(bigint_col), 3)), 2, 10)
WHERE-- 你的条件语句,比如 id = 1id = 1;
<!-- MyBatis的mapper文件 -->
<update id="updateBit">UPDATE your_table_nameSET your_bigint_column = bitor(bitand(your_bigint_column, bnot(1 << 20)), (#{value} << 20))WHERE your_condition
</update>这里使用了两个位运算符:bitand(a, b): 对两个bigint数进行按位与操作。bitor(a, b): 对两个bigint数进行按位或操作。bnot(x): 对bigint数进行按位取反操作,结果是把x的第y位取反。<<: 左移运算符,用于将一个整数左移指定的位数。确保你的mapper接口中有相应的方法:

UPDATE your_table_name
SET your_bigint_column = BIN(CONV(CONV(your_bigint_column, 2, 10) + POW(2, 19 - 1), 2, 10))
WHERE your_condition;your_table_name是你的表名,your_bigint_column是你想要更新的列名,your_condition是你的更新条件。请注意,这个例子中假设了以下几点:你想要将第20位设置为1。你的列是无符号的,因此最高位是第20位。如果是有符号的,请适当调整位数。如果你想将第20位设置为0或某个特定值,只需要将POW(2, 19 - 1)中的1改为你想要设置的值(以二进制表示)。如果是将第20位设置为0,就是POW(2, 19 - 0)

三、demo

1、使用bigint类型存储bit

  总览

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.example</groupId><artifactId>bit-demo</artifactId><version>1.0-SNAPSHOT</version><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>3.2.4</version><relativePath/></parent><properties><maven.compiler.source>17</maven.compiler.source><maven.compiler.target>17</maven.compiler.target><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--尽量不要同时导入mybatis 和 mybatis_plus,避免版本差异--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-spring-boot3-starter</artifactId><version>3.5.5</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.13</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><scope>test</scope></dependency></dependencies></project>
server.port=6666
server.servlet.context-path=/bitDemo
#mysql
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3308/demo?useUnicode=true&characterEncoding=utf-8&useSSL=false
spring.datasource.username=root
spring.datasource.password=wtyy
#mybatis
mybatis.mapper-locations=classpath*:mapper/*Mapper.xml
#
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
1.1、表
create table demo.user_sys_flag
(id      int auto_incrementprimary key,flag    bigint      null,user_id varchar(50) null
);
1.2、dto与枚举
package com.bit.demo.dto;import com.baomidou.mybatisplus.annotation.TableName;
import com.bit.demo.enums.UserSysFlagEnums;
import com.bit.demo.util.BitUtil;
import lombok.Builder;
import lombok.Data;@Data
@Builder
@TableName("user_sys_flag")
public class UserSysFlagDTO {private Integer id;private Long flag;private String userId;public boolean isEnableFlag1(){return BitUtil.isSet(flag,UserSysFlagEnums.FLAG_1.bitPosition);}public boolean isEnableFlag2(){return BitUtil.isSet(flag,UserSysFlagEnums.FLAG_2.bitPosition);}public boolean isEnableFlag60() {return BitUtil.isSet(flag,UserSysFlagEnums.FLAG_60.bitPosition);}
}
package com.bit.demo.enums;public enum UserSysFlagEnums {FLAG_1("flag_1",1L),FLAG_2("flag_2",1L<<1),FLAG_3("flag_3",1L<<2),FLAG_60("flag_60",1L<<59);public final String key;public final Long bitPosition;UserSysFlagEnums(String key, Long bitPosition){this.key = key;this.bitPosition = bitPosition;}
}
1.3、dao
package com.bit.demo.repository;import com.baomidou.mybatisplus.core.conditions.AbstractWrapper;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.bit.demo.dto.UserSysFlagDTO;
import com.bit.demo.mapper.UserSysFlagMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;@Repository
public class UserSysFlagRepository {@Autowiredpublic UserSysFlagMapper userSysFlagMapper;public void insert(UserSysFlagDTO userSysFlagDTO) {userSysFlagMapper.insert(userSysFlagDTO);}public UserSysFlagDTO getByUserId(String userId) {LambdaQueryWrapper<UserSysFlagDTO> userQuery = new LambdaQueryWrapper<>();userQuery.eq(UserSysFlagDTO::getUserId,userId);return userSysFlagMapper.selectOne(userQuery);}public void updateFlagByUserIdAndIndex(String userId, int index, int indexValue) {userSysFlagMapper.updateFlagByUserIdAndIndex(userId,index,indexValue);}public String queryBitByUserId(Integer bitLength,String userId) {return userSysFlagMapper.queryBitByUserId(bitLength,userId);}
}
package com.bit.demo.mapper;import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.bit.demo.dto.UserSysFlagDTO;
import org.apache.ibatis.annotations.Param;public interface UserSysFlagMapper extends BaseMapper<UserSysFlagDTO> {void updateFlagByUserIdAndIndex(@Param("userId") String userId,@Param("index") int index,@Param("bitValue") int bitValue);String queryBitByUserId(@Param("bitLength")Integer bitLength,@Param("userId") String userId);
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.bit.demo.mapper.UserSysFlagMapper"><update id="updateFlagByUserIdAndIndex">UPDATE user_sys_flagSET flag =CASEWHEN #{bitValue} = 1 THEN flag | (1 &lt;&lt; ${index})   <!-- Setting the 20th bit to 1 -->ELSE flag &amp; ~(1 &lt;&lt; ${index})                     <!-- Setting the 20th bit to 0 -->ENDwhere user_id=#{userId}</update><select id="queryBitByUserId" resultType="string">SELECTCONCAT('b', LPAD(BIN(flag), ${bitLength}, '0')) AS formatted_bit_valueFROMuser_sys_flag WHEREuser_id = #{userId}</select></mapper>

1.4、service
package com.bit.demo.service.impl;import com.bit.demo.dto.UserSysFlagDTO;
import com.bit.demo.mapper.UserSysFlagMapper;
import com.bit.demo.repository.UserSysFlagRepository;
import com.bit.demo.service.UserSysFlagService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service("userSysFlagService")
public class UserSysFlagServiceImpl implements UserSysFlagService {@Autowiredprivate UserSysFlagRepository userSysFlagRepository;@Autowiredprivate UserSysFlagMapper userSysFlagMapper;@Overridepublic void insert(UserSysFlagDTO userSysFlagDTO) {userSysFlagRepository.insert(userSysFlagDTO);}@Overridepublic UserSysFlagDTO getByUserId(String userId) {return userSysFlagRepository.getByUserId(userId);}@Overridepublic void updateFlagByUserIdAndIndex(String userId, int index, int indexValue) {userSysFlagRepository.updateFlagByUserIdAndIndex(userId,index,indexValue);}@Overridepublic String queryBitByUserId(Integer bitLength,String userId) {return userSysFlagRepository.queryBitByUserId(bitLength,userId);}
}
1.5、util
package com.bit.demo.util;import com.bit.demo.enums.UserSysFlagEnums;public class BitUtil {public static boolean isSet(long options, long bit) {return (options & bit) == bit;}
}
1.6、启动类
package com.bit.demo;import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@MapperScan("com.bit.demo.mapper")
@SpringBootApplication
public class BitApplication {public static void main(String[] args) {SpringApplication.run(BitApplication.class, args);}
}
1.7、test
package com.bit.demo;import com.bit.demo.dto.UserSysFlagDTO;
import com.bit.demo.service.UserSysFlagService;
import lombok.extern.slf4j.Slf4j;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;@SpringBootTest(classes = {BitApplication.class}, webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
@RunWith(SpringRunner.class)
@Slf4j
public class UserSysFlagTest {@Autowiredprivate UserSysFlagService userSysFlagService;//1、初始化。最大64位,假如需要60个开关,0代表关,1代表开,默认为关。@Testpublic void init() {UserSysFlagDTO userSysFlagDTO = UserSysFlagDTO.builder().userId("zs").flag(0L).build();userSysFlagService.insert(userSysFlagDTO);}//2、更新,更新第n位的flag@Testpublic void update() {//将 `bigint` 转换为 `bit` 字符串,将第index位设置为indexValue,然后转换回 `bigint`//index从0开始String userId = "zs";int index = 0;int indexValue = 0;userSysFlagService.updateFlagByUserIdAndIndex(userId,index,indexValue);}//3、查询@Testpublic void query() {UserSysFlagDTO userSysFlagDTO = userSysFlagService.getByUserId("zs");log.info(userSysFlagDTO.toString());log.info("flag1值为:{}", userSysFlagDTO.isEnableFlag1());log.info("flag2值为:{}", userSysFlagDTO.isEnableFlag2());log.info("flag60值为:{}", userSysFlagDTO.isEnableFlag60());}//查询二进制@Testpublic void queryBit(){Integer bitLength = 64;String userId = "zs";String bitStr = userSysFlagService.queryBitByUserId(bitLength,userId);System.out.println(bitStr);}
}
1.8、测试:
(1)初始化

如我初始化了ls,默认是0

(2)更新第1位

   更新ls第1位为1

String userId = "ls";int index = 0;int indexValue = 1;

 queryBit:可以看到第一位是1了

query:可以看到isEnableFlag1是true了

 (3)更新其他位

如更新第60位为1:

  String userId = "ls";int index = 59;int indexValue = 1;

 queryBit:可以看到第60位是1了

query:可以看到isEnableFlag1、isEnableFlag60都是true了

(4)再次更新第1位

更新为0,也即关闭功能

String userId = "ls";int index = 0;int indexValue = 0;
queryBit查看:

query查看:

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/329444.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++——动态规划

公共子序列问题 ~待补充 最长公共子序列 对于两个字符串A和B&#xff0c;A的前i位和B的前j位的最大公共子序列必然是所求解的一部分&#xff0c;设dp[i][j]为串A前i位和B串前j位的最长公共子序列的长度&#xff0c;则所求答案为dp[n][m]&#xff0c;其中n&#xff0c;m分别为…

【linux】进程(一)

1. 冯诺依曼体系结构 计算机基本都遵循着冯诺依曼体系 我们使用的计算器是由一个个硬件构成的&#xff1a; 中央控制器&#xff08;CPU&#xff09; &#xff1a; 运算器 控制器 等输入设备 : 键盘&#xff0c;鼠标&#xff0c;网卡 等输出设备 : 显示器&#xff0c;网卡 等…

Python概述

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 了解Python Python&#xff0c;本义是指“蟒蛇”。1989年&#xff0c;荷兰人Guido van Rossum发明了一种面向对象的解释型高级编程语言&#xff0c;…

[数据集][目标检测]弹簧上料检测数据集VOC+YOLO格式142张2类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;142 标注数量(xml文件个数)&#xff1a;142 标注数量(txt文件个数)&#xff1a;142 标注类别…

实现本地访问云主机,以及在云主机搭建FTP站点

前言 云计算是一种基于互联网的计算模式&#xff0c;通过网络提供按需访问的计算资源和服务。核心概念是把计算能力视作一种公共资源&#xff0c;用户可以根据自身需求动态分配和管理这些资源。 云主机 ECS (Elastic Compute Server)是一种按需获取的云端服务器&#xff0c;提…

ArrayList和LinkedList的使用

ArrayList List<> list new ArrayList<>(); LinkedList

树的非递归遍历(层序)

层序是采用队列的方式来遍历的 就比如说上面这颗树 他层序的就是&#xff1a;1 24 356 void LevelOrder(BTNode* root) {Que q;QueueInit(&q);if (root){QueuePush(&q, root);}while (!QueueEmpty(&q)){BTNode* front QueueFront(&q);QueuePop(&q);print…

二十五、openlayers官网示例CustomOverviewMap解析——实现鹰眼地图、预览窗口、小窗窗口地图、旋转控件

官网demo地址&#xff1a; Custom Overview Map 这个示例展示了如何在地图上增加一个小窗窗口的地图并跟随着地图的旋转而旋转视角。 首先加载了一个地图。其中 DragRotateAndZoom是一个交互事件&#xff0c;它可以实现按住shift键鼠标拖拽旋转地图。 const map new Map({int…

家政预约小程序05服务管理

目录 1 设计数据源2 后台管理3 后端API4 调用API总结 家政预约小程序的核心是展示家政公司提供的各项服务的能力&#xff0c;比如房屋维护修缮&#xff0c;家电维修&#xff0c;育婴&#xff0c;日常保洁等。用户在选择家政服务的时候&#xff0c;价格&#xff0c;评价是影响用…

深度学习之基于Tensorflow卷积神经网络脑肿瘤分类识别系统

欢迎大家点赞、收藏、关注、评论啦 &#xff0c;由于篇幅有限&#xff0c;只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 一、项目背景 脑肿瘤是医学领域的一个重要问题&#xff0c;对人类的健康构成了严重威胁。传统的脑肿瘤分类识别方法…

MVVM_MVVMLight架构

介绍 MVVMLight是一个实现MVVM模式的轻量级框架&#xff08;相对于Prism&#xff09;&#xff0c;能够更好的帮助我们开发WPF Windows Phone、Windows 8、SilverLight相关项目。 安装 在NuGet 工具箱上搜索MVVMLight进行下载 下载后它帮你生成ViewModel文件夹&#xff0c;里面…

顶顶通呼叫中心中间件-自动外呼输入分机号(比如隐私号)(mod_cti基于FreeSWITCH)

顶顶通呼叫中心中间件-自动外呼输入分机号(比如隐私号)(mod_cti基于FreeSWITCH) 比如有些人的号码是这样的就需要用上自动外呼输入分机号了 号码1&#xff1a;182XXXX8111-1234 号码2&#xff1a;182XXXX8222 如果号码是这样的就根据以下步骤配置 注意使用这个需要&#xff1a;…

web4.0-元宇宙虚拟现实

互联网一直在不断演变和改变我们的生活方式&#xff0c;从Web逐渐 1.0时代的静态网页到Web 2.0时代的社会性和内容制作&#xff0c;再从Web逐渐 在3.0阶段&#xff0c;互联网发展一直推动着大家时代的发展。如今&#xff0c;大家正站在互联网演化的新起点上&#xff0c;迈入Web…

k8s pv 一直是release状态

如下图所示&#xff0c;pv 一直是release状态 这个时候大家可能就会想到现在我的 PVC 被删除了&#xff0c;PV 也变成了 Released 状态&#xff0c;那么我重建之前的 PVC 他们不就可以重新绑定了&#xff0c;事实并不会&#xff0c;PVC 只能和 Available 状态的 PV 进行绑定。…

OpenAI宫斗剧番外篇: “Ilya与Altman联手对抗微软大帝,扫除黑恶势力”,“余华”和“莫言”犀利点评

事情是这样的。 小编我是一个重度的智谱清言用户&#xff0c;最近智谱清言悄悄上线了一个“划词引用”功能后&#xff0c;我仿佛打开了新世界的大门。我甚至用这个小功能&#xff0c;玩出来了即将为你上映的《OpenAI宫斗剧番外篇》。 3.5研究测试&#xff1a;hujiaoai.cn 4研…

Github上传时报错The file path is empty的解决办法

问题截图 文件夹明明不是空的&#xff0c;却怎么都上传不上去。 解决方案&#xff1a; 打开隐藏文件的开关&#xff0c;删除原作者的.git文件 如图所示&#xff1a; 上传成功&#xff01;

vue三级联动组件

背景 项目中经常出现三级下拉框组件的要求&#xff0c;这种组件其中一级发生变化&#xff0c;子级的组件就会发生变化如果这一个组件&#xff0c;单独作为搜索条件使用&#xff0c;很好写&#xff0c;同时作为搜索条件和form回写组件&#xff0c;回显就比较困难 子组件代码 将与…

Vitis HLS 学习笔记--控制驱动TLP - Dataflow视图

目录 1. 简介 2. 功能特性 2.1 Dataflow Viewer 的功能 2.2 Dataflow 和 Pipeline 的区别 3. 具体演示 4. 总结 1. 简介 Dataflow视图&#xff0c;即数据流查看器。 DATAFLOW优化属于一种动态优化过程&#xff0c;其完整性依赖于与RTL协同仿真的完成。因此&#xff0c;…

JavaEE-文件IO1

文章目录 一、什么是文件IO?1.1 IO1.2 文件1.2.1 路径1.2.2 文件分类 二、使用Java针对文件系统进行操作 一、什么是文件IO? 1.1 IO IO分别代表Input和Output即输入和输出。比如我的电脑可以从网络上下载文件&#xff0c;也可以通过网络上传文件或者我把我的内存中的数据保…