数据库扩展性设计:使用二进制解决一条记录关联多个状态的问题
程序开发中,经常遇到一条记录有多个状态位,比如一条商品,他属于热门,新品,特卖。我们的数据库如何设计呢?
一般有几种方法
(1)建立关联表
关联表字段:关系Id,商品Id,属性Id
查询:使用关联表的方式,查询某属性的商品。
程序:写入时,写商品表和关联表;
(2)将多个属性存在一个字段中,用|分割
状态存储在一个字段中,比如某条商品属于热卖,新品和特卖,则字段存储的值:01|02|03
SQL查询:使用like
程序处理:(1)取值需要先将01,02,03分割,再处理。(2)写入需要先将01,02,03组合为一个字符串再存储。
以上两种方法可以可以解决多个状态关联的问题,但是存在以下问题
(1)增加了表和程序复杂度;
(2)需要改代码,不利于扩展;
有没有更好的方法,处理一条记录多个状态的问题呢?
使用二进制位,每个位置,代表一个状态,多个位置代表多个状态,存储的时候转换为int类型存储。
以产品属性存储为例。
热门:0000 0001
新品:0000 0010
特卖:0000 0100
多个状态的组合
热门+新品:0000 0011
热门+特卖:0000 0101
热门+新品+特卖:0000 0111
存储时将二进制转换为int数值。
二进制位的查询
以Oracle为例,使用bitadd函数,如:
SELECT * FROM T_PRODUCT WHERE bitand(property,1)=1
java中对二进制位的处理
1)是否包含:&与运算符,比如:(1&3)==1
2)组装:|或运算符,比如 1|2=3
如果再扩展,清仓状态,可以使用 0000 1000
二进制实现的好处
以上内容讲解了使用二进制位来表示状态的方式,实现数据库设计和程序调用。有以下好处
1)存储精简
2)扩展性强
缺点:
1)增加了理解复杂度;
以下是四个状态情况的二进制与十进制存储对照表:

微信公众号:itfly8,欢迎大家加入。专注大型分布式网站架构,微服务架构,大数据,架构模式,设计模式。
posted on 2016-11-14 17:57 ITFLY8架构师之家 阅读(3599) 评论(6) 编辑 收藏 举报
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)