博客
关于我
SQL反模式学习笔记11 限定列的有效值
阅读量:399 次
发布时间:2019-03-06

本文共 1012 字,大约阅读时间需要 3 分钟。

目标:限定列的有效值,将一列的有效字段值约束在一个固定的集合中。类似于数据字典。

 

反模式:在列定义上指定可选值

            1、 对某一列定义一个检查约束项,这个约束不允许往列中插入或者更新任何会导致约束失败的值:

              create table Bugs(status varchar(20) check(status in('new','in progress','fixed')))。

            2、使用域或者用户自定义类型(UDT)等方法。

          3、使用触发器:编写一个触发器,当修改指定列的内容时触发,将被修改的值和允许输入的值进行匹配,

                如果不符合则产生一个错误中断操作。

  缺点:

  1、 无法查询出所有的约束值来供上层应用程序使用。

           不能用select distinct status from Bugs,因为可能有的status目前还没有存储。

    维护不好的话,还有可能造成列表和数据库存储的值,不一致。

  2、增加新的约束值,需要修改数据库定义或者触发器。

  3、废弃或修改某个值,可能要修改大量的数据,风险很大也不合理。

  4、可移植性差,check约束、域,或者UDT在各种数据库中的支持形式并不统一。

 

如何识别反模式:当出现以下情况时,可能是反模式

  1、我们不得不将数据库下线,才能在程序中加入一个新的选项。

  2、这个Status列可以填入这些候选值中的一个。我们不应该改变这个后选值列表。

  3、程序代码中关于业务规则的选项列表和数据库中的值又不同步了。

 

合理使用反模式

  1、在后选值几乎不变化的时候可以使用。

  2、存储没有业务逻辑且不需要改变的候选值时非常方便。

          比如存储一对二选一切相互对立的值:Left/Right、On/Off等。

  3、Check约束可以再更多的场景下使用,比如用来检测一个时间区间中start永远小于end。

 

解决方案:创建一张检查表(类似于字典表),每一行包含一个允许在列中出现的候选值,然后在目标表中定义一个外键约束。

              个人经验:在系统中创建一个数据字典表,管理所有可变的候选集合。

结论:在验证固定集合的候选值时使用元数据;

        在验证可变集合的候选值时使用数据。

 

 

SQL反模式,系列学习汇总

1

2、

3、

4、

5、

6、 

7、

8、

9、

10、

11、

12、

13、

14、

15、

16、

17、

18、

19、 

20、

21、

22、

 

转载地址:http://jkfkz.baihongyu.com/

你可能感兴趣的文章
List数组排序
查看>>
VMware vSphere 离线虚拟机安装 BIND 9
查看>>
说说第一份工作
查看>>
dojo/request模块整体架构解析
查看>>
dojo/aspect源码解析
查看>>
Web性能优化:What? Why? How?
查看>>
Javascript定时器学习笔记
查看>>
dojo的发展历史
查看>>
Liunx百宝箱(Centos补充)
查看>>
Python存储系统(Redis)
查看>>
C语言指针收藏
查看>>
.net 4种单例模式
查看>>
T4 生成数据库实体类
查看>>
C#搞个跨平台的桌面NES游戏模拟器
查看>>
手把手教你安装Eclipse最新版本的详细教程 (非常详细,非常实用)
查看>>
《带你装B,带你飞》pytest成魔之路4 - fixture 之大解剖
查看>>
互联网App应用程序测试流程及测试总结
查看>>
根据轨迹分析出用户家在哪
查看>>
PostgreSQL查询表名称及表结构
查看>>
是什么?评估分类器的常用概念----准确率,精确率,召回率
查看>>