
1 realpg PRO 基本除非特殊情况,我的 mysql 的任何列都是禁止 null 的…… |
2 liuyao729 2017-12-05 23:19:46 +08:00 0 |
3 zhx1991 2017-12-05 23:22:05 +08:00 如果是字符串类型就是空串, 如果是数字类型就是 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 作为默认值。 比如一个人的宠物名,存在压根没有宠物的情况,有宠物但没有起名。 |