MySQL的where表达式中的各种运算符的用法和细节

小故事

今天在研究mysql的where表达式中的运算符的时候,遇到一个有意思的问题。
问题是:以id为主键,选择id在5到10之间的数据
小华说:where id>5 and id <10;就搞定了
小朋说:where id between 5 and 10;就搞定了
翻译起来,好像两句话的意思是一样的,其实这里是有一个细节的。
小华的说法,最终选择的是6,7,8,9
小朋的说法,最终选择的是5,6,7,8,9,10
看似是差不多的描述,实际是结果是不一样的。因为between and运算符虽然和> ,>=, <,<= ,!=等运算符是同一层次,但是范围是不同的。between and 实际是取目标范围的闭区间。

在这里插入图片描述如果将小华的说法改成:where id>=5 and id <=10,那就和小朋的回答一致了。
所以为避免日后混淆,今日将mysql运算符研究了一遍,进行一个较全面的总结。


mysql运算符分类

掌握mysql的运算符对于编写SQL语句是非常重要的,可以使我们高效写语句,不犯错。
大体上mysql可以分为以下几种运算符

算术运算符
用于在select语句中对数值进行算术操作,包括加(+)、减(-)、乘(*)、除(/)和取模(%)。

比较运算符
用于比较两个表达式的值,返回的结果是真或假。常用的比较运算符包括等于(=)、不等于(<>或!=)、大于(>)、小于(<)、大于等于(>=)和小于等于(<=)。

逻辑运算符
主要有三种——AND、OR和NOT。它们用于判断两个布尔表达式之间的关系,并且返回TRUE或FALSE。

位运算符
将数字转换为二进制后,在位级别上进行操作。主要有按位与(&)、按位或(|)、按位异或(^)、按位取反(~)、左移位(<<)和右移位(>>)。

赋值运算符
用于将一个值赋给一个变量,主要有等于号(=)和加等于(+=)、减等于(-=)、乘等于(*=)、除等于(/=)和取模等于(%=)等复合赋值运算符。

其他运算符
REGEXP(用于正则表达式匹配)和BETWEEN…AND(用于查找指定范围内的数据)。


where表达式中的运算符

  • =:判断两个值是否相等。
  • <>!=:判断两个值是否不相等。
  • <:判断左边的值是否小于右边的值。
  • >:判断左边的值是否大于右边的值。
  • <=:判断左边的值是否小于等于右边的值。
  • >=:判断左边的值是否大于等于右边的值。
  • BETWEEN:判断某个值是否在某个范围内。
  • IN:判断某个值是否在一个列表中。
  • LIKE:模糊匹配,判断某个值是否包含某个模式。
  • IS NULL:判断某个值是否为空。
  • NOT:否定运算符,取反WHERE表达式中的条件。

除了这些常见的运算符,MySQL还支持一些其他的运算符,如逻辑运算符(AND、OR、NOT)和位运算符(&、|、^、~、<<、>>)。
在这里插入图片描述

  1. 等于运算符的注意点:使用等于运算符时,如果比较的值是NULL,那么结果总是未知的(NULL)。

  2. 不等于运算符的注意点:使用不等于运算符时,如果比较的值是NULL,那么结果总是未知的(NULL)。

  3. 小于和大于运算符的注意点:使用小于和大于运算符时,如果比较的值是NULL,那么结果总是未知的(NULL)。

  4. BETWEEN运算符的注意点:使用BETWEEN运算符时,如果比较的值是NULL,那么结果总是未知的(NULL)。

  5. IN运算符的注意点:使用IN运算符时,如果比较的值是NULL,那么结果总是未知的(NULL)。

  6. LIKE运算符的注意点:使用LIKE运算符时,可以使用通配符,例如%或_,但是使用通配符会影响查询的性能。

  7. NOT运算符的注意点:使用NOT运算符时,会将结果反转,例如NOT TRUE的结果是FALSE,NOT FALSE的结果是TRUE。

  8. AND和OR运算符的注意点:使用AND和OR运算符时,需要注意它们的优先级,可以使用括号来明确优先级。

  9. IS NULL和IS NOT NULL运算符的注意点:使用IS NULL和IS NOT NULL运算符时,需要注意NULL的特殊性,NULL不等于任何值,包括NULL本身。


between and 和 and运算符的区别

这个在文章最开头已经说过了,但重要的事,有必要再强调一遍。
BETWEEN ANDAND是MySQL的where表达式中的两个不同的运算符,它们的作用和使用方式也不同。

BETWEEN AND运算符用于指定一个范围,在这个范围内的值都会被选中。它的语法如下:
在这里插入图片描述

AND运算符则是逻辑运算符之一,用于连接多个条件,只有当所有条件都为真时,整个条件才为真。它的语法如下:
在这里插入图片描述


in运算符需要注意的点

在这里插入图片描述
在这里插入图片描述
==注意看这两张图的区别,in运算符是没有模糊查询功能的。它仅能用来查询指定项。

★★★★★比如我在整个列表中查看有没有叫‘张三’的人,而不能查看名字里有没有带‘三’的人==


  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小猫娃来啦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值