加入收藏 | 设为首页 | 会员中心 | 我要投稿 常州站长网 (https://www.0519zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MYsql中NULL与空字符串空差异详解

发布时间:2022-06-15 14:24:36 所属栏目:MySql教程 来源:互联网
导读:很多朋友会错误的认为NULL与空字符串 是相同的。这看似是一件不重要的事情,但是在MySQL中,这两者是完全不同的。NULL是指没有值,而则表示值是存在的,只不过是个空值。 为了进行NULL处理,可使用IS NULL和IS NOT NULL操作符以及IFNULL()函数。 在SQL中,NU
  很多朋友会错误的认为NULL与空字符串’ ’是相同的。这看似是一件不重要的事情,但是在MySQL中,这两者是完全不同的。NULL是指没有值,而”则表示值是存在的,只不过是个空值。
 
 
  为了进行NULL处理,可使用IS NULL和IS NOT NULL操作符以及IFNULL()函数。
 
  在SQL中,NULL值与任何其它值的比较(即使是NULL)永远不会为“真”。包含NULL的表达式总是会导出NULL值,除非在关于操作符的文档中以及表达式的函数中作了其他规定,下述示例中的所有列均返回NULL:
 
  mysql> SELECT NULL, 1+NULL, CONCAT('Invisible',NULL);
 
  如果打算搜索列值为NULL的列,不能使用expr = NULL测试,下述语句不返回任何行,这是因为,对于任何表达式,expr = NULL永远不为“真”,代码如下:
 
  mysql> SELECT * FROM my_table WHERE phone = NULL;
 
  想查找NULL值,必须使用IS NULL测试,在下面的语句中,介绍了查找NULL电话号码和空电话号码的方式,代码如下:
 
  用LOAD DATA INFILE读取数据时,对于空的或丢失的列,将用''更新它们。如果希望在列中具有NULL值,应在数据文件中使用N。在某些情况下,也可以使用文字性单词“NULL”。
 
  使用DISTINCT、GROUP BY或ORDER BY时,所有NULL值将被视为等同的。
 
  使用ORDER BY时,首先将显示NULL值,如果指定了DESC按降序排列,NULL值将最后显示。
 
  对于聚合(累计)函数,如COUNT()、MIN()和SUM(),将忽略NULL值。对此的例外是COUNT(*),它将计数行而不是单独的列值。例如,下述语句产生两个计数。首先计数表中的行数,其次计数age列中的非NULL值数目:
 
  mysql> SELECT COUNT(*), COUNT(age) FROM person;
 
  对于某些列类型,MySQL将对NULL值进行特殊处理。如果将NULL插入TIMESTAMP列,将插入当前日期和时间。如果将NULL插入具有AUTO_INCREMENT属性的整数列,将插入序列中的下一个编号.
 
  这就相当于厂子给职工分房子,一共只有一套,老张和老李都想要,可是经理告诉老张,下次有您的房子,可是老李压根就没人搭理他。所以老张的房子是“空”的,因为这是空白支票,不过毕竟经理张口了,而老李的房子就是NULL的,因为根本就没有人考虑过他。
 
  二者的区别不大,但是如果不仔细的话可能会使我们限入困境。因为在PRIMARY KEY字段中是不能使用NULL值的。这一点我们应该记住哈。

(编辑:常州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读