1
realpg 2017-12-05 23:18:25 +08:00
基本除非特殊情况,我的 mysql 的任何列都是禁止 null 的……
|
2
liuyao729 2017-12-05 23:19:46 +08:00
0
|
3
zhx1991 2017-12-05 23:22:05 +08:00 2
如果是字符串类型就是空串, 如果是数字类型就是 0 或者 -1
千万别用 null, 坑到姥姥家 |
4
est 2017-12-05 23:22:43 +08:00
当然是留一个字符串 "Null"
|
6
whx20202 2017-12-06 00:01:29 +08:00
在不同的数据库 /版本 /引擎下,null 经常在排序,count,索引需要额外注意,所以建议用默认值
|
7
kunluanbudang 2017-12-06 00:10:05 +08:00
可能几乎是共识了
禁止任何 NULL, 一般留一个表示「不合法情况」的默认值, 如 "" 0 什么的 |
8
nondanee 2017-12-06 00:35:22 +08:00 via Android
为了 AVG()会用 null,其他情况""😂
|
9
yangqi 2017-12-06 00:37:13 +08:00
具体要根据字段含义来,空白和 Null 含义是不一样的,Null 表示该字段没有数据,空白则表示有数据,是空白。
|
10
love2075904 2017-12-06 09:39:49 +08:00
@yangqi 同意,不过如果该列会参与排序就有点坑爹了。
|
11
paragon 2017-12-06 10:05:30 +08:00
null 和“”的语义是不一样的~
|
12
jjx 2017-12-06 10:16:58 +08:00
如果该字段要被查询, 就别用空, 否则 查询 field is null or field='' , 这个是不能走查询优化的
|
13
gouchaoer 2017-12-06 10:31:38 +08:00
avg 也可以用 case when 来避免 null 吧,如果你用-1 之类的来表示没有值啥的
|
14
eslizn 2017-12-06 10:34:56 +08:00
还是看需求,而不是一味的禁止 null,禁止 join 等等,比如某个可选的唯一字段,可为 null 是最好的选择
|
15
Erroad 2017-12-06 11:01:14 +08:00
NOT NULL DEFAULT ""
|
16
metrxqin 2017-12-11 11:07:14 +08:00
取决于需求,如果业务属性存在以下三种情况:
1,可能压根不存在; 2,存在但为空; 3,存在不为空,则使用 NULL 作为默认值。 比如一个人的宠物名,存在压根没有宠物的情况,有宠物但没有起名。 |