postgreSQL is not null 和 !=NULL有什么区别吗?
一、postgreSQL is not null 和 !=NULL的区别
按照sql标准来说 = null这种语法本来就是错误的,在oracle postgresql mssql等企业级数据库中这种语法根本就不支持。
判断是否为null的标准sql规范是is null 和is not null。
sql是个“公共”的数据库查询语言有他自己的标准。mysql postgresql mssql oracle等都不同程度的遵循不同的sql标准并且各自都又在自家产品中加入了他自己的特色。
postgresql默认不支持 = null这种语法,但是在配置文件中可以设置开启支持,会自动的把=null转换成is null,!=null自动转换成is not null
null就是null,null不等于空字符串。
默认情况下做比较条件时使用关键字“is null”和“is not null”。
如果你一定要使用!= null来进行条件判断,需要加上这个命令语句:SET ANSI_NULLS OFF,这时数据库进入ANSI SQL非标准模式,你会发现IS NOT NULL 和 != null 是等效的了。
这里使用的是模式切换命令SET ANSI_NULLS[ON/OFF]。ON值采用ANSI SQL严格标准,OFF值采用非标准兼容模式。另外SET ANSI_DEFAULTS [ON/OFF]命令也可以实现标准的切换,只是这个命令控制的是一组符合SQL-92标准的设置,其中就包括Null值的标准。
延伸阅读:
二、mysql字符集和排序规则
所为字符集,就是用来定义字符在数据库中的编码的集合。常见的字符集有:utf8(支持中文)和AccIS(不支持中文)
数据库中的排序规则用来定义字符在进行排序和比较的时候的一种规则。常见的如下:
(1) utf8_general_ci 不区分大小写,utf8_general_cs 区分大小写
(2) utf8_bin 规定每个字符串用二进制编码存储,区分大小写,可以直接存储二进制的内容
说明:所为排序规则,就是指字符比较时是否区分大小写,以及是按照字符编码进行比较还是直接用二进制数据比较
utf8_unicode_ci和utf8_general_ci对中、英文来说没有实质的差别。
utf8_general_ci校对速度快,但准确度稍差。
utf8_unicode_ci准确度高,但校对速度稍慢。
如果你的应用有德语、法语或者俄语,请一定使用utf8_unicode_ci。一般用utf8_general_ci就够了。
所以一般字符集用utf-8,排序规则用utf8_general_ci

猜你喜欢LIKE
相关推荐HOT
更多>>
为什么SQL数据库用B树索引?
一、SQL数据库用B树索引的原因1、平衡性B树是一种自平衡的树型数据结构,它能够自动调整和保持树的平衡状态。这意味着无论是在插入、删除还是查...详情>>
2023-10-15 17:27:31
Python的pymysql、mysql、mysqlx库都有什么区别?
一、Python的pymysql、mysql、mysqlx库的区别Python的pymysql、mysql、mysqlx库连接数据库所使用的引擎不一样,简单操作都没什么影响的。如果一...详情>>
2023-10-15 16:54:43
CHNS数据库怎么查找想要的数据?
一、CHNS数据库查找想要的数据的方法CHNS数据库是指中国健康与营养调查(China Health and Nutrition Survey)数据库,该数据库提供了中国家庭...详情>>
2023-10-15 16:31:56
502 Bad Gateway怎么解决?
一、502 Bad Gateway的解决办法“502 Bad Gateway”错误是指在客户端(通常是您的浏览器)和服务器之间建立网关或代理时出现问题。1、刷新页面...详情>>
2023-10-15 16:03:47热门推荐
MySQL LEFT JOIN 和 JOIN查询有什么区别?
沸写好的java可执行程序在其他电脑上如何使用?
热oracle19c与oracle12c有哪些区别?
热Python的字典和数据库有什么区别?
新mysql字符串内部是怎么比较大小的?
Excel怎样从Access中实时读取更新的数据?
mysql中,逻辑删除对索引以及性能会造成什么影响?
什么是 ZIP 文件,工作机制是什么?
sql中group by,having语句在select前执行,那么为什么能用select中的别名?
public class和class的区别有哪些?
Python的应用领域及优缺点?
postgreSQL is not null 和 !=NULL有什么区别吗?
Oracle执行SQL报错ORA-00922是什么原因?
为什么SQL数据库用B树索引?
技术干货






