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 << ${index}) <!-- Setting the 20th bit to 1 -->ELSE flag & ~(1 << ${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查看:

相关文章:
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 (B10101010);-- 查询并格式化输出 SELECT id,bit_value,CONCAT(b, LPAD(BIN(bit_value),…...
Lua中table.sort()使用方式
table.sort(tab,compare) 参数如下: tab:表名 compare:比较规则函数名 简略写法: a {1,2,3} table.sort(a,function(a,b) return a>b end) compare这个参数是一个函数,它有两个参数,你可以理解为表中的两个不同元素&…...
数组与指针声明小问题
1、int *p &a; 是 C 语言中的一条语句,它涉及指针的声明和初始化。让我们逐步解释这一行代码的含义: int *p:这是一个指针声明。它声明了一个名为 p 的变量,该变量是一个指向 int 类型数据的指针。 &a:这是取…...
【Java】手把手学会数组的使用
数组的基本用法 创建数组 基本语法: // 动态初始化 数据类型 [] 数组名称 new 数据类型 [] { 初始化数据 }; // 静态初始化 数据类型 [] 数组名称 { 初始化数据 }; 代码示例: int[] array1 {1,2,3,4,5};int[] array2 new int[]…...
音视频开发9 FFmpeg 解复用框架--如何将一个影音文件(mp4文件/wav文件) 最终播放起来
一,播放器框架 二 常用音视频术语 容器/文件(Conainer/File): 即特定格式的多媒体文件, 比如mp4、flv、mkv等。 媒体流(Stream): 表示时间轴上的一段连续数据࿰…...
vue实现页面渲染时候执行某需求
1. 前言 在之前的项目中,需要实现一个监控token是否过期从而动态刷新token的功能,然而在登录成功后创建的监控器会在浏览器刷新点击或者是通过导航栏输入网址时销毁... 2. 试错 前前后后始过很多方法,在这里就记录一下也许也能为各位读者排…...
Python小游戏——俄罗斯方块
文章目录 项目介绍环境配置代码设计思路1.初始化和导入库:2.定义颜色和屏幕尺寸:3.定义游戏逻辑:4.游戏循环: 源代码效果图 项目介绍 俄罗斯方块游戏是一款经典的益智游戏,玩家通过旋转和移动各种形状的方块ÿ…...
Moto和Inter字节序
inter: 低地址按照start_bit位放低字节依次往高字节填充 MotoLsb: 低地址按照start_bit位放高字节,依次往低字节填充MotoMsb:高字节按照start_bit位放低地址,依次往高字节填充...
外汇天眼:野村证券和Laser Digital与GMO互联网集团合作发行日元和美元稳定币
野村控股和Laser Digital将与GMO互联网集团合作,在日本探索发行日元和美元稳定币。GMO互联网集团的美国子公司GMO-Z.com Trust Company, Inc. 在纽约州金融服务部的监管框架下,在以太坊、恒星币和Solana等主要区块链上发行稳定币。GMO-Z.com Trust Compa…...
Python怎么使用getattr?
getattr() 是 Python 的内置函数,用于获取对象的属性值。它接受三个参数:对象、属性名称以及一个可选的默认值。如果对象具有指定的属性,getattr() 会返回该属性的值;如果对象没有该属性,并且提供了默认值,…...
[算法] 优先算法(三):滑动窗口(上)
🌸个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 🏵️热门专栏:🍕 Collection与数据结构 (92平均质量分)https://blog.csdn.net/2301_80050796/category_12621348.html?spm1001.2014.3001.5482 🧀Java …...
[蓝桥杯 2020 省 A1] 超级胶水
一.题目 题目描述 小明有 n 颗石子,按顺序摆成一排。 他准备用胶水将这些石子粘在一起。 每颗石子有自己的重量,如果将两颗石子粘在一起,将合并成一颗新的石子,重量是这两颗石子的重量之和。 为了保证石子粘贴牢固࿰…...
读书笔记分享
1.苏格拉底只在需要的时候才索取,那样便能以最少的物质满足自身的要求。他认为每个人都天生体质脆弱,只有在贫乏的环境中才会锻炼地强壮起来。生活中的大多数人认为,奢华才是幸福的生活。无休止的物质积聚,让人们每天生活在一个内…...
考试宝典——软件过程与管理重点知识总结
概论 软件工程三要素 过程方法工具 软件过程的定义 软件过程是用于软件开发及维护的一系列活动、方法及实践。 常见软件过程分类(五大类) 客户-供应商过程:内部直接影响到客户、外部直接影响开发、向客户交付软件以及软件正确操作与使用的过…...
穿越时空的工厂之旅:探索可视化三维场景的奥秘
在科技日新月异的今天,我们似乎总是在不断追求着更加高效、智能的生产方式。 传统的工厂管理方式往往依赖于平面图纸、纸质文档和现场巡查,这不仅效率低下,而且容易出错。而三维可视化技术通过3D建模和虚拟现实技术,将工厂内部的各…...
2024年推荐的适合电脑和手机操作的线上兼职副业平台
总是会有人在找寻着线上兼职副业,那么在如今的2024年,互联网提供了诸多方便,无论你是宝妈、大学生、程序员、外卖小哥还是打工族,如果你正在寻找副业机会,那么这篇文章将为你提供一些适合电脑和手机操作的线上兼职副业…...
传感器的静态特性
传感器的静态特性是指传感器在稳态(输入量为常量或变化极慢时)输入信号作用下,传感器输出与输入信号之间的关系。这种关系一般用曲线、数学表达式或表格来表示。传感器的静态特性是传感器的基本特性之一,其描述了传感器在不考虑迟…...
如果jupyter notebook不能实现网页自动跳转,参考下面的链接
一招搞定Jupyter-notebook命令行打开之后不能自动跳转浏览器_一招搞定jupter notebook命令行打开之后-CSDN博客...
顺序表实现通讯录项目
目录 一.实现功能: 二.文件结构 三.代码实现 1.初始化 2.通讯录的销毁 3.通讯录添加数据 4.通讯录删除数据 5.通讯录的修改 6.展现通讯录数据 7.通讯录查找 四.代码 SeqList.h Contact.h Contact.c test(通讯录).c 一.实现功能: ⾄少能够存…...
【ai】pycharm设置软件仓库编译运行基于langchain的chatpdf
联想笔记本 y9000p创建python工程: 使用langchain支持openai的向量化embedding安装软件包 发现没有openai ,添加软件仓库打开工具窗口 点击设置...
Linux 文件类型,目录与路径,文件与目录管理
文件类型 后面的字符表示文件类型标志 普通文件:-(纯文本文件,二进制文件,数据格式文件) 如文本文件、图片、程序文件等。 目录文件:d(directory) 用来存放其他文件或子目录。 设备…...
云计算——弹性云计算器(ECS)
弹性云服务器:ECS 概述 云计算重构了ICT系统,云计算平台厂商推出使得厂家能够主要关注应用管理而非平台管理的云平台,包含如下主要概念。 ECS(Elastic Cloud Server):即弹性云服务器,是云计算…...
相机Camera日志实例分析之二:相机Camx【专业模式开启直方图拍照】单帧流程日志详解
【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了: 这一篇我们开始讲: 目录 一、场景操作步骤 二、日志基础关键字分级如下 三、场景日志如下: 一、场景操作步骤 操作步…...
连锁超市冷库节能解决方案:如何实现超市降本增效
在连锁超市冷库运营中,高能耗、设备损耗快、人工管理低效等问题长期困扰企业。御控冷库节能解决方案通过智能控制化霜、按需化霜、实时监控、故障诊断、自动预警、远程控制开关六大核心技术,实现年省电费15%-60%,且不改动原有装备、安装快捷、…...
《通信之道——从微积分到 5G》读书总结
第1章 绪 论 1.1 这是一本什么样的书 通信技术,说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号(调制) 把信息从信号中抽取出来&am…...
第一篇:Agent2Agent (A2A) 协议——协作式人工智能的黎明
AI 领域的快速发展正在催生一个新时代,智能代理(agents)不再是孤立的个体,而是能够像一个数字团队一样协作。然而,当前 AI 生态系统的碎片化阻碍了这一愿景的实现,导致了“AI 巴别塔问题”——不同代理之间…...
Java线上CPU飙高问题排查全指南
一、引言 在Java应用的线上运行环境中,CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时,通常会导致应用响应缓慢,甚至服务不可用,严重影响用户体验和业务运行。因此,掌握一套科学有效的CPU飙高问题排查方法&…...
Go语言多线程问题
打印零与奇偶数(leetcode 1116) 方法1:使用互斥锁和条件变量 package mainimport ("fmt""sync" )type ZeroEvenOdd struct {n intzeroMutex sync.MutexevenMutex sync.MutexoddMutex sync.Mutexcurrent int…...
[大语言模型]在个人电脑上部署ollama 并进行管理,最后配置AI程序开发助手.
ollama官网: 下载 https://ollama.com/ 安装 查看可以使用的模型 https://ollama.com/search 例如 https://ollama.com/library/deepseek-r1/tags # deepseek-r1:7bollama pull deepseek-r1:7b改token数量为409622 16384 ollama命令说明 ollama serve #:…...
通过 Ansible 在 Windows 2022 上安装 IIS Web 服务器
拓扑结构 这是一个用于通过 Ansible 部署 IIS Web 服务器的实验室拓扑。 前提条件: 在被管理的节点上安装WinRm 准备一张自签名的证书 开放防火墙入站tcp 5985 5986端口 准备自签名证书 PS C:\Users\azureuser> $cert New-SelfSignedCertificate -DnsName &…...
