本文基于Mysql5.7版本的参考资料:

https://dev.mysql.com/doc/refman/5.7/en/working-with-null.html

https://dev.mysql.com/doc/search/?d=12&p=1&q=null+empty+string

https://dev.mysql.com/doc/refman/5.7/en/static-format.html

https://dev.mysql.com/doc/refman/5.7/en/dynamic-format.html

昨天新建一个表用于存储表结构信息:

create table tablist(TABLE_SCHEMA varchar(40),TABLE_NAME varchar(40),COLUMN_NAME varchar(40),COLUMN_TYPE varchar(40),
IS_NULLABLE varchar(10),COLUMN_DEFAULT varchar(40),COLUMN_COMMENT varchar(1000),REMARK varchar(2000)); insert into tablist(TABLE_SCHEMA,TABLE_NAME,COLUMN_NAME,COLUMN_TYPE,IS_NULLABLE,COLUMN_DEFAULT,COLUMN_COMMENT)
select TABLE_SCHEMA,TABLE_NAME,COLUMN_NAME,COLUMN_TYPE,IS_NULLABLE,COLUMN_DEFAULT,COLUMN_COMMENT
from information_schema.`COLUMNS` where TABLE_SCHEMA='leo';

然后查询tablist表:

看看有哪些列没有comment于是:

select * from tablist where COLUMN_COMMENT is null;

查到的结果居然是Empty set。不过从以上查询结果和navicat都能看出:null值在结果集中显示的是'null'的单词,而空字符串则显示为空。

使用select * from tablist where COLUMN_COMMENT='';查询正常。

在MySQL中NULL值和空字符''是不一样的,这点可能会引起很多新人的困惑,因此查询官网相关的页面总结如下:

  • 两者的查询方式不一样:NULL值查询使用is null/is not null查询,而empty string可以使用=或者!=、<、>等算术运算符,这点算是最主要的区别了。

以下列出的几点算不上区别,只是一些NULL和空字符的使用总结:

  • 在MySQL当中,0和NULL默认可以作为布尔类型的false,任意其他值可以用于表示True,不过一般用1作为True的默认布尔值。
  • 在MySQL当中,NULL值在group by、order by、distinct语句中被认为是相等的,会被分在同一组。
  • 对于MySQL的unique index来说,null值是可以存在多个的,也就是说unique index不会过滤null值。
  • 在MySQL当中,使用order by对包含NULL值的列排序,NULL值会默认排在前边,order by ... desc时排在最后。
  • 同Oracle、MSSQL一样你可以在包含NULL值的列上创建索引,但仅限于MyISAM, InnoDB和MEMORY存储引擎。
  • 默认情况下LOAD DATA会把空字符或缺失字段全部设置为空字符。如果想要插入NULL值请使用\N,在某些特殊情况下也可以使用NULL字符,但需要设置正确的LOAD DATA语法项,参考https://dev.mysql.com/doc/refman/5.7/en/load-data.html
  • 在使用COUNT(), MIN(), and SUM()等函数时,NULL值会被忽略,当然count(*)除外。
  • 对于TIMESTAMP列,插入的NULL值会被CURRENT_TIMESTAMP替代。
  • 对于myisam引擎,null值占用额外的存储空间(1bit),空字符串则完全不占用空间。
  • 对于索引查询的影响,无论是NULL还是空字符目前的测试结果表明都没有太大区别,这点与oracle中is null的查询可能会导致全表扫描不一样。
  • 以上提到的关于NULL值的分组、聚合等,基本都适用于空字符。
在实际工作中建议将空值列全部设为NULL,而不是'',因为很多情况下null都会比空字符好处理,空字符还可能引发各种混淆。
此外关于空字符和NULL值对于索引的影响,可以参考https://www.cnblogs.com/leohahah/p/8425813.html

Mysql的NULL和Empty String的更多相关文章

  1. Mysql 数据库默认值选 ''" 、Null和Empty String的区别

    两者的查询方式不一样:NULL值查询使用is null/is not null查询,而empty string可以使用=或者!=.<.>等算术运算符,这点算是最主要的区别了. 对于myis ...

  2. Summary: Difference between null and empty String

    String s1 = ""; means that the empty String is assigned to s1. In this case, s1.length() i ...

  3. 'EF.Utility.CS.ttinclude' returned a null or empty string.

    需要安装https://www.microsoft.com/en-us/download/details.aspx?id=40762

  4. mysql default null empty string concat varchar text

    text不可设置默认值 null  empty string   前者update 初始值时 我响应,但不报错

  5. [shiro] Wildcard string cannot be null or empty. Make sure permission strings are properly formatted.

    访问某页面时,出现了这个异常: java.lang.IllegalArgumentException: Wildcard string cannot be null or empty. Make su ...

  6. Check if a string is NULL or EMPTY using PowerShell

    http://techibee.com/powershell/check-if-a-string-is-null-or-empty-using-powershell/1889 Check if a s ...

  7. (后端)shiro:Wildcard string cannot be null or empty. Make sure permission strings are properly formatted.

    访问某页面时,出现了这个异常: java.lang.IllegalArgumentException: Wildcard string cannot be null or empty. Make su ...

  8. (转)Java 中关于String的空对象(null) ,空值(empty),空格

    原文出处:Java 中关于String的空对象(null) ,空值(empty),空格 定义 空对象: String s = null; 空对象是指定义一个对象s,但是没有给该对象分配空间,即没有实例 ...

  9. Net Core 下 Newtonsoft.Json 转换字符串 null 替换成string.Empty

    原文:Net Core 下 Newtonsoft.Json 转换字符串 null 替换成string.Empty public class NullToEmptyStringResolver : De ...

随机推荐

  1. 搭建企业级PPTP服务器

    本文收录在企业项目实战系列 一.VPN 介绍 1.介绍 虚拟私人网络(英语:Virtual Private Network,缩写为VPN)是一种常用于连接中.大型企业或团体与团体间的私人网络的通讯方法 ...

  2. QT 应用程序测试

    添加环境 export QTEDIR='/Qt5' export QTINC='/Qt5/include/' export QTLIB='/Qt5/lib' export QT_QPA_FB_TSLI ...

  3. xmanager 连接centos 7桌面

    1.前言 工作中服务器有时候需要图形处理一些事物,那么这个时候就需要远程连接方式,XDMCP,VNC,RDP,我今天介绍一下xdmp怎么使用与配置(x display manager control ...

  4. [转]MySQL修改时区的方法小结

    本文转自:https://www.cnblogs.com/mracale/p/6064447.html 这篇文章主要介绍了MySQL修改时区的方法,总结分析了三种常见的MySQL时区修改技巧,包括命令 ...

  5. nginx配置虚拟机

    在/usr/local/nginx/conf目录下nginx.conf文件是nginx的配置文件. 一.通过端口号区分虚拟机 在nginx.conf文件中添加一个Service节点,修改端口号: se ...

  6. python基础学习(十二)变量进阶

    目录 1. 变量的引用 1.1 引用的概念 1.2 变量引用 的实例 1.3 函数的参数和返回值的传递 2. 可变和不可变类型 哈希 (hash) 3. 局部变量和全局变量 3.1 局部变量 3.2 ...

  7. linux下的~/

    在linux里面,~/表示的是个人目录,例如你的账户是student,那么~/代表的是/home/student/

  8. SQL优化一(SQL使用技巧)

    1.行列转换: decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值); select decode(sign(变量1-变量2),-1,变量1,变量2) from dual ...

  9. 深入理解SpringCloud与微服务构建

    旭日Follow_24 的CSDN 博客 ,全文地址请点击: https://blog.csdn.net/xuri24/article/details/81742534 目录 一.SpringClou ...

  10. C# % 和 /

    /相当于整数除法中的除号,%相当于余号5 除以 2 = 2 余 1,因此 5/2=2,5%2=1.