mysql的not null 细节请教

WBOY
发布: 2016-06-23 14:17:34
原创
885 人浏览过

比如这样的一条sql ddl语句:

password char(32) not null default "",//有md5
登录后复制


既然都定义了not null了,那么用户就强制必要添加密码了,那后面来个默认值是不是有点多余?而且我长度规定是32位,默认值是空,

感觉有not null 的时候,默认值,没有存在的必要,就算存在,他的值属性也不合字段的属性约定啊?求解!


回复讨论(解决方案)

恰恰相反

在not null的时候如果你不输入东西  就按默认的输入

换句话说   你设置not null了最好(必须)设置default

毫不相干!

password 只是一个名字而已,对于数据库而言没有任何意义

not null default "" 的目的在于:如果没有对其赋值,在取默认值为空串。即插入时可缺省该项
如果仅 not null,那么插入时该项必须有值,否则出错

如果约定 password 必须有值,那么定义时应为
password char(32) not null,
而不是
password char(32) not null default "",

习惯上都给个default的

毫不相干!

password 只是一个名字而已,对于数据库而言没有任何意义

not null default "" 的目的在于:如果没有对其赋值,在取默认值为空串。即插入时可缺省该项
如果仅 not null,那么插入时该项必须有值,否则出错

如果约定 password 必须有值,那么定义时应为
password char(32) not null,
而不是
password char(32) not null default "",
正解,你的需求是:
password char(32) not null

若加上default “”,在你不传值的情况下,数据库会存储长度为0的字符串""。
null != “”

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板