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