文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-08-31 08:44

关注

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表达式中的运算符

除了这些常见的运算符,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运算符是没有模糊查询功能的。它仅能用来查询指定项。

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


来源地址:https://blog.csdn.net/dyk11111/article/details/130547648

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯