"空值"是对null值的中文叫法,两者同指一个东西。
我想楼主是想弄清楚null(空值)与零长度字符串''(或称为空字符串)之间的区别。
在代码里"零长度字符串"用一对没有间隔的英文引号''表示,它的数据类型是明确的即属于字符型,存储"零长度字符串"是要占用物理磁盘空间的;
而null值其数据类型是未知的,它不会占用物理磁盘空间。
在不存在约束限制的情况我们可以将Null值插入任何数据类型的字段里,而零长度字符串''只能插入到字符型数据类型字段中,插入其它类型字段会报错。
我们通过实测看看null(空值)与零长度字符串''(或称为空字符长)之间的区别:
1)输出所有的记录
select * from students
注意:此例输出源表中的全部记录,含null(空值)和零长度字符串''.
2)输出电话为Null(空值)的记录
select * from students where phone is null
注意:此例只输出含Null(空值)的记录
3)输出电话为零长度字符串的记录
select * from students where phone=''
注意:此例只输出含零长度字符串的记录。
4)输出电话不是零长度字符串的记录
select * from students where phone<>''
注意:此例MySQL的处理方式有些特别,连含Null值得记录也排除掉了,这与MSSQL的处理方式有点不一致。
5)输出电话不为空的记录
select * from students where phone is not null
注意:此例只要不含Null值的记录都予以输出
已经添加了mysql的nuget但是ef中还是没有mysql在vs2013中使用MySQL连接entityFramework经常会遇到这个问题:您的项目引用了最新实体框架;但是,找不到数据连接所需的与版本兼容的实体框架数据提供程序。请退出此向导,安装兼容提供程序,重新生成您的项目,然后再执行 *** 作
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)