什么是mysql中列的默认值
admin
2023-04-19 10:04:32
0

下面讲讲关于什么是mysql中列的默认值,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完什么是mysql中列的默认值这篇文章你一定会有所受益。

在 MySQL 中,每个字段定义都包含附加约束或者修饰符,这些可以用来增加对所输入数据的约束。

NULL 和 NOT NULL 修饰符、DEFAULT 修饰符,AUTO_INCREMENT 修饰符。

NULL 和 NOT NULL 修饰符

可以在每个字段后面都加上这 NULL 或 NOT NULL 修饰符来指定该字段是否可以为空(NULL),

还是说必须填上数据 (NOT NULL)。MySQL 默认情况下指定字段为 NULL 修饰符,如果一个字段指定为NOT NULL,

MySQL 则不允许向该字段插入空值(这里面说的空值都为 NULL),因为这是 “规定”。

但是在自增列和 TIMESTAMP 字段中,这个规则并不适用。

向这些字段中插入 NULL 值将会导致插入下一个自动增加的值或者当前的时间戳。

mysql> create table t10 (
    -> id int not null default 0,
    -> name char(10) not null default ''
    -> );
Query OK, 0 rows affected (0.01 sec)
#插入2个值是ok的.
mysql> insert into t10 values (1,"lisi");
Query OK, 1 row affected (0.08 sec)
#只插入一个值,也是ok的.
mysql> insert into t10 (id) values (2);
Query OK, 1 row affected (0.00 sec)
#发现未插入的name列继承default的“”值.
mysql> select * from t10;
+----+------+
| id | name |
+----+------+
|  1 | lisi |
|  2 |      |
+----+------+
2 rows in set (0.00 sec)
mysql> select * from t10 where name = '';
+----+------+
| id | name |
+----+------+
|  2 |      |
+----+------+
1 row in set (0.00 sec)

#创建t11表,字段id,name不为null.
mysql> create table t11 ( id int not null, name char(10) not null);
Query OK, 0 rows affected (0.01 sec)
#如果只插入其中一列,发现报错,其中另一列不能为空.
mysql> insert into t11 (id) values (2);
ERROR 1364 (HY000): Field 'name' doesn't have a default value
#如果第二列插入"null"也会报错,设置字段为not null.
mysql> insert into t11 (id,name) values (2,null);
ERROR 1048 (23000): Column 'name' cannot be null
#插入“0”,""字段是ok的.
mysql> insert into t11 (id,name) values (2,0);
Query OK, 1 row affected (0.00 sec)
mysql> insert into t11 (id,name) values (2,"");
Query OK, 1 row affected (0.01 sec)

结论:

如果一个字段中没有指定 DEFAULT 修饰符,MySQL 会依据这个字段是 NULL 还是 NOT NULL 自动设置默认值。

如果指定字段可以为 NULL,则 MySQL 为其设置默认值为 NULL。

如果是 NOT NULL 字段,MySQL 对于数值类型插入 0,字符串类型插入空字符串.

对于以上什么是mysql中列的默认值相关内容,大家还有什么不明白的地方吗?或者想要了解更多相关,可以继续关注我们的行业资讯板块。

相关内容

热门资讯

荣耀首款自研耳夹式耳机官宣即将... 快科技5月13日消息,日前,荣耀首席营销官关海涛宣布,荣耀全场景团队自研首款耳夹式耳机马上上市,并称...
谷歌推出Googlebooks... IT之家 5 月 13 日消息,2026 年 I/O 开发者大会下周(5 月 19~20 日)召开之...
自控所推动GNC专业智能化升级 来源:滚动播报 (来源:中国航空报) 本报讯 5月6日,航空工业自控所召开 GNC+AI关键技术研发...
华电电力申请数据库访问方法专利... 国家知识产权局信息显示,华电电力科学研究院有限公司申请一项名为“数据库访问方法、装置、设备及介质”的...
苏州率先打造数据流通利用新范式 数据,作为第五大生产要素 具有流动性强、非消耗性、非均质性等特点 苏州率先打造数据流通利用新范式 夯...
伊媒披露伊美新一轮谈判5个先决... 当地时间5月12日,据伊朗法尔斯通讯社援引知情人士消息报道,伊朗对与美国新一轮谈判提出的5个先决条件...
英国将向霍尔木兹海峡多国护航行... 当地时间12日,总台记者从英国国防部获悉,英国将向在霍尔木兹海峡执行任务的多国护航行动提供无人机、战...
强化技术引领场景培育政策保障 ... 5月11日,省长叶建春就脑机接口技术与产业创新工作开展专题调研。他强调,脑机接口是培育未来产业发展新...
上海交大王如竹教授领衔撰写的“... 4月30日,国际制冷学会(IIR,International Institute of Refrig...
非人类身份蔓延:智能体AI真正... 长期以来,企业依赖服务账户、API密钥、OAuth令牌等各类非人类身份凭证,使不同服务能够在数字环境...