mysql中运算符有几种

mysql中运算符有几种,第1张

mysql中有4类运算符,它们是:

算术运算符

比较运算符

逻辑运算符

位 *** 作运算符

算术 *** 作符

算术 *** 作符是SQL中最基本的 *** 作运算符,主要有一下几种运算符:

+(加)、 -(减)、 *(乘)、 /(除)、 %(求余或者模)

比较运算符

一个比较运算符的结果总是1,0或者是NULL。MySQL中的比较运算符有:

=、<=>、<>(!=)、<=、>=、>、IS NULL、IS NOT NULL、LEAST、GREATEST、BETWEEN . . . AND. . . 、ISNULL、IN、NOT IN、LIKE、REGEXP

逻辑运算符

逻辑运算符的求值所得结果均为TRUE、FALSE或NULL。

逻辑运算符有:

NOT 或者 !

AND 或者 &&

OR 或者 ||

XOR(异或)

位运算符

位运算符是用来对二进制字节中的位进行测试、移位或者测试处理。位运算符有:

位或(|)

位与(&)

位异或(^ )

位左移(<<)

位右移(<<)

位取反(~)

"空值"是对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),投影对应于SELECT子句,选择对应于WHERE子句,连接对应于JOIN子句,但除没有直接的对应语句,需要根据题目的实际含义书写复杂的SQL,通常都会包含子查询。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/8522343.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-17
下一篇 2023-04-17

发表评论

登录后才能评论

评论列表(0条)

保存