mysql的not null 细节请教
程序员文章站
2024-01-16 11:40:04
...
比如这样的一条sql ddl语句:
既然都定义了not null了,那么用户就强制必要添加密码了,那后面来个默认值是不是有点多余?而且我长度规定是32位,默认值是空,
感觉有not null 的时候,默认值,没有存在的必要,就算存在,他的值属性也不合字段的属性约定啊?求解!
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几个语法符号的有关问题
推荐阅读
-
mysql的not null 细节请教
-
mysql - 请教关于PHP方法传入参数的问题及依赖注入的适用场景?
-
mysql 请教where a.id=b.id 和join on a.id=b.id 在效率上的区别
-
请教php关于mysql数库库布局的问题
-
php-请教用PHP备份MYSQL数据的做法
-
mysql的not null 细节请问
-
确保所有的非空(Non-NULL)值都是唯一的_MySQL
-
mysql - PHP使用PDO库查询数据库除了NULL所有字段都返回的是字符串
-
Thinkphp中如何表达MYSQL中的某字段不为空is not null
-
请教个mysql问题.关于获取查询结果中某一个字段的最大值(按照其他字段排序)