比如这样的一条sql ddl语句:
password char(32) not null default "",//有md5既然都定义了not null了,那么用户就强制必要添加密码了,那后面来个默认值是不是有点多余?而且我长度规定是32位,默认值是空,感觉有not null 的时候,默认值,没有存在的必要,就算存在,他的值属性也不合字段的属性约定啊?求解!
password char(32) not null default "",//有md5既然都定义了not null了,那么用户就强制必要添加密码了,那后面来个默认值是不是有点多余?而且我长度规定是32位,默认值是空,感觉有not null 的时候,默认值,没有存在的必要,就算存在,他的值属性也不合字段的属性约定啊?求解!
如果仅 not null,那么插入时该项必须有值,否则出错如果约定 password 必须有值,那么定义时应为
password char(32) not null,
而不是
password char(32) not null default "",
password char(32) not null若加上default “”,在你不传值的情况下,数据库会存储长度为0的字符串""。
null != “”