我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何将零或空字符串插入到定义为 NOT NULL 的 MySQL 列中?

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何将零或空字符串插入到定义为 NOT NULL 的 MySQL 列中?

将列声明为“NOT NULL”意味着该列不接受 NULL 值,但接受零 (0),并且空字符串本身就是一个值。因此,如果我们想将零或空字符串插入到定义为 NOT NULL 的 MySQL 列中,就不会有问题。下面将 0 和空字符串与 NULL 进行比较就会清楚 -

mysql> Select 0 IS NULL, 0 IS NOT NULL;
+-----------+---------------+
| 0 IS NULL | 0 IS NOT NULL |
+-----------+---------------+
|         0 |             1 |
+-----------+---------------+
1 row in set (0.00 sec)

以上结果集显示零 (0) 不为 NULL。这意味着零 (0) 本身就是一个值,因为我们知道 NULL 意味着没有值。

mysql> Select '' IS NULL, '' IS NOT NULL;
+------------+----------------+
| '' IS NULL | '' IS NOT NULL |
+------------+----------------+
|          0 |              1 |
+------------+----------------+
1 row in set (0.00 sec)

上面的结果集显示空字符串(‘’)不为NULL。这意味着空字符串 ('') 本身就是一个值,因为我们知道 NULL 意味着没有值。

示例

mysql> create table test(id int NOT NULL, Name Varchar(10));
Query OK, 0 rows affected (0.19 sec)

mysql> Insert into test6(id, name) values('1', 'Gaurav'),('0','Rahul'),('','Aarav');
Query OK, 3 rows affected, 1 warning (0.08 sec)
Records: 3 Duplicates: 0 Warnings: 1

Warning (Code 1366): Incorrect integer value: '' for column 'id' at row 3

mysql> Select * from test;
+----+--------+
| id | Name |
+----+--------+
|  1 | Gaurav |
|  0 | Rahul  |
|  0 | Aarav  |
+----+--------+
3 rows in set (0.00 sec)

从上面的结果集中可以看出,我们可以将零(0)一个空字符串(“”)插入到声明为 NOT NULL 的列中。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何将零或空字符串插入到定义为 NOT NULL 的 MySQL 列中?

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何将零或空字符串插入到定义为 NOT NULL 的 MySQL 列中?

将列声明为“NOT NULL”意味着该列不接受 NULL 值,但接受零 (0),并且空字符串本身就是一个值。因此,如果我们想将零或空字符串插入到定义为 NOT NULL 的 MySQL 列中,就不会有问题。下面将 0 和空字符串与 NULL
2023-10-22

为什么每当我将空字符串插入声明为 NOT NULL 的 MySQL 列时,它显示 0 而不是空字符串?

这是因为插入空字符串意味着我们正在插入一些值而不是 NULL。空字符串显然映射到零作为整数。换句话说,我们可以说,通过插入空字符串,我们向 MySQL 提供了一个整数表示为 INT 0 的值。考虑以下示例,其中我们插入了一个空字符串,并被
2023-10-22

当我将空字符串插入声明为 NOT NULL 的 MySQL 列时,数据类型起什么作用?

当我们将空字符串插入声明为 NOT NULL 的 MySQL 列时,结果集中空字符串的表示取决于数据类型。我们知道,在插入空字符串时,我们向 MySQL 提供整数表示为 INT 0 的值。现在,如果该列具有 INTEGER 数据类型,那么
2023-10-22

编程热搜

目录