设为首页 加入收藏

TOP

数据库扩展性设计:使用二进制解决一条记录关联多个状态的问题
2017-10-13 10:41:49 】 浏览:9061
Tags:数据库 展性 设计 使用 二进制 解决 记录 关联 多个 状态 问题
程序开发中,经常遇到一条记录有多个状态位,比如一条商品,他属于热门,新品,特卖。我们的数据库如何设计呢?
一般有几种方法
(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)增加了理解复杂度;
 
以下是四个状态情况的二进制与十进制存储对照表:
 

编程开发网
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇设计模式(十一):迭代器模式 下一篇FreeMarker:怎么使用

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

array(4) { ["type"]=> int(8) ["message"]=> string(24) "Undefined variable: jobs" ["file"]=> string(32) "/mnt/wp/cppentry/do/bencandy.php" ["line"]=> int(214) }