SQL反模式学习笔记14 关于Null值的使用
目标:辨别并使用Null值
反模式:将Null值作为普通的值,反之亦然
1、在表达式中使用Null:
Null值与空字符串是不一样的,Null值参与任何的加、减、乘、除等其他运算,结果都是Null;
Null值与False也不同。And、Or和Not三个bool操作如果设计Null,结果很迷惑。
2、搜索运行为空的列:任何与Null的比较逗返回“未知”,既不是True,也不是False。
在Where表达式中只能使用 Is Null 或者 Is Not Null,其他操作都查询不到结果。
3、不能使用Null作为参数传入查询表达式中。
要避免上述问题,可以使用约束,设置列禁止Null。存储值必须是有意义的内容。
如何识别反模式:当出现以下情况时,可能是反模式
1、我如何将没有值(Null)的列取出来?
2、将字符串与Null进行拼接操作,结果返回Null
合理使用反模式:
使用Null并不是反模式,反模式是将Null作为一个普通值处理或者使用一个普通的值来取代Null的作用。
有一种情况可以讲Null视为普通值,就是导入或者导出数据的时候。
解决方案:将Null值视为特殊值
1、在标量表达式中使用null
进行=、<>、+、||操作时,只要有一个null值,结果就为null。
2、在布尔表达式中使用null
布尔表达式中,只有:null and false结果为false,null or true结果为true,其它情况结果都是null。
3、检索null值
使用 is null、is not null
4、声明not null列
有时候可以通过使用default值来避免null,但有时候却不可以这么做。
5、使用动态默认值
SqlServer中的Coalesec()与isnull()函数
SQL反模式,系列学习汇总
1、SQL反模式学习笔记1 开篇
2、SQL反模式学习笔记2 乱穿马路
3、SQL反模式学习笔记3 单纯的树
4、SQL反模式学习笔记4 建立主键规范【需要ID】
5、SQL反模式学习笔记5 外键约束【不用钥匙的入口】
6、SQL反模式学习笔记6 支持可变属性【实体-属性-值】
7、SQL反模式学习笔记7 多态关联
8、SQL反模式学习笔记8 多列属性
9、SQL反模式学习笔记9 元数据分裂
10、SQL反模式学习笔记10 取整错误
11、SQL反模式学习笔记11 限定列的有效值
12、SQL反模式学习笔记12 存储图片或其他多媒体大文件
13、SQL反模式学习笔记13 使用索引
14、SQL反模式学习笔记14 关于Null值的使用
15、SQL反模式学习笔记15 分组
16、SQL反模式学习笔记16 使用随机数排序
17、SQL反模式学习笔记17 全文搜索
18、SQL反模式学习笔记18 减少SQL查询数据,避免使用一条SQL语句解决复杂问题
19、SQL反模式学习笔记19 使用*号,隐式的列
20、SQL反模式学习笔记20 明文密码
21、SQL反模式学习笔记21 SQL注入
22、SQL反模式学习笔记22 伪键洁癖,整理数据