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

news2024/12/23 22:55:27

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

  • 小故事
  • mysql运算符分类
  • where表达式中的运算符
  • between and 和 and运算符的区别
  • in运算符需要注意的点

小故事

今天在研究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运算符是没有模糊查询功能的。它仅能用来查询指定项。

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


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/500088.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

玩机搞机----修改手机各项参数工具解析 过验证 变新机

任何的芯片原则上都可以修改当前机型的任何参数。包括但不限于高通 MTk 展讯..... 等其他芯片。众所周知&#xff0c;有的机型 有的版本可以直接修改&#xff0c;有的不行。至于具体原因可以参考我以往的帖子 安卓玩机搞机技巧综合资源-----修复基带 改串码 基带qcn 改相关参数…

三、c++学习(指针引用详解)

上一次直播好像过去很久了&#xff0c;中间有加班&#xff0c;有5 1假期等&#xff0c;现在5 1放假完了&#xff0c;所以继续卷。 C学习&#xff0c;b站直播视频 3.1 指针 这个指针&#xff0c;考虑了很久&#xff0c;一直不知道在哪个地方介绍&#xff0c;为啥纠结&#xf…

Solr(2):Solr的安装

1 安装前的概述 &#xff08;1&#xff09;solr是基于lucene而lucene是java写的&#xff0c;所以solr需要jdk----当前安装的solr-7.5需要jdk-1.8及以上版本&#xff0c;下载安装jdk并设置JAVA_HOME即可。 &#xff08;2&#xff09;下载solr&#xff0c;然后解压即可&#xf…

Map对象的用法(JS)

&#x1f4dd;个人主页&#xff1a;爱吃炫迈 &#x1f48c;系列专栏&#xff1a;数据结构与算法 &#x1f9d1;‍&#x1f4bb;座右铭&#xff1a;道阻且长&#xff0c;行则将至&#x1f497; 文章目录 MapkeyMap常用语法Map其他语法创建map的其他方式 Map Map是一个键值对形式…

FPGA设计之控制集优化详解

目录 一、前言 二、Control Set控制集 三、Control Set控制集优化 四、优劣 一、前言 在工程设计优化中&#xff0c;综合阶段优化中有一项常见的优化&#xff0c;控制集&#xff08;control set&#xff09;优化&#xff0c;在vivado的Synthesis中有对该配置项的解释&#x…

Android Jetpack组件化之ORM 数据库访问框架详解

一、对象关系映射 - ORM / Object Relational Mapping Android 系统中使用的数据库是 SQLite 关系型数据库 , 使用 Android 提供的 api 访问 SQLite 数据库非常繁琐 , 由此出现了很多 ORM 框架 ; ORM 英文全称 Object Relational Mapping , 对象关系映射 ; 对象关系映射 ORM …

“智能指针:C++中优雅的内存管理解决方案“

前言 欢迎来到&#x1f496;小K&#x1f496;的&#x1f49e;C专栏&#x1f49e;&#xff0c;内存泄漏指由于疏忽或错误造成程序未能释放已经不再使用的内存的情况&#xff0c;这是C和C程序员的噩梦之一。本节将为大家带来解决办法—>智能指针 文章目录 前言1、简介2、为什么…

【移动端网页布局】flex 弹性布局 ⑤ ( 设置侧轴单行子元素排列方式 | align-items 样式说明 | 代码示例 )

文章目录 一、设置子元素是否换行 : align-items 样式说明1、 align-items 样式引入2、 align-items 样式属性值 二、代码示例1、 代码示例 - 默认样式2、 代码示例 - 设置主轴水平居中3、 代码示例 - 设置侧轴垂直居中4、 代码示例 - 设置侧轴从下到上排列5、 代码示例 - 设置…

C++之类和对象(二)

目录 前言 类的6个默认成员函数 1.构造函数 1.1 概念 1.2 特性 2. 析构函数 2.1 概念 2.2 特性 3. 拷贝构造函数 3.1 概念 3.2 特征 4.赋值运算符重载 4.1 运算符重载 4.2.赋值运算符重载 4.3 前置和后置重载 5. .const成员 6.取地址及const取地址操作符重载 前…

【二叉搜索树】

1 二叉搜索树概念 二叉搜索树又称二叉排序树&#xff0c;它或者是一棵空树 &#xff0c;或者是具有以下性质的二叉树 : 若它的左子树不为空&#xff0c;则左子树上所有节点的值都小于根节点的值 若它的右子树不为空&#xff0c;则右子树上所有节点的值都大于根节点的值 它的左…

Android“真正的”模块化

作者&#xff1a;bytebeats 模块化背后的原则概述 “如果说SOLID原则告诉我们如何将砖块排列成墙和房间, 那么组件原则则告诉我们如何将房间排列成建筑.” ~ Robert C. Martin, Clean Architecture 你应该分层打包还是分特性打包?还有其他方法吗? 如何提高项目的编译时间? 你…

将Python环境迁移到另一台设备上

本方法可以将一台电脑上的python环境迁移到另一台电脑上&#xff0c;可以省去一个一个包pip的麻烦。本文以pytorch的迁移为例。 一、从源环境备份安装包 在原来的电脑的Conda控制台中使用语句 pip freeze > c:\myrequirement.txt 后面跟的参数是文件的路径和文件名&#x…

Spring MVC自定义拦截器--Spring MVC异常处理

目录 自定义拦截器 什么是拦截器 ● 说明 自定义拦截器执行流程分析图 ● 自定义拦截器执行流程说明 自定义拦截器应用实例 ● 应用实例需求 创建MyInterceptor01 创建FurnHandler类 在 springDispatcherServlet-servlet.xml 配置拦截器 第一种配置方式 第二种配置方…

linux 互斥量pthread_mutex

专栏内容&#xff1a;linux下并发编程个人主页&#xff1a;我的主页座右铭&#xff1a;天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物&#xff0e; 目录 前言 概述 原理 初始化 进程和线程使用的不同点 死锁 接口 基本API 属性设置 …

探索机器翻译:从统计机器翻译到神经机器翻译

❤️觉得内容不错的话&#xff0c;欢迎点赞收藏加关注&#x1f60a;&#x1f60a;&#x1f60a;&#xff0c;后续会继续输入更多优质内容❤️ &#x1f449;有问题欢迎大家加关注私戳或者评论&#xff08;包括但不限于NLP算法相关&#xff0c;linux学习相关&#xff0c;读研读博…

Osek网络管理及ETAS实现

OSEK/VDX&#xff08;Offene Systeme und deren Schnittstellen fr die Elektronik in Kraftfahrzeugen / Vehicle Distributed eXecutive&#xff09;是一种用于嵌入式系统&#xff08;尤其是汽车电子控制单元&#xff09;的开放标准。它旨在提供一种统一、可互操作的软件架构…

关于 《python 从入门到实践》的 matplotlib 随机漫步小项目

使用 python 生成随机漫步数据&#xff0c;再使用 matplotlib 将数据呈现。 所谓随机漫步&#xff1a; 每次行走的路径都是完全随机的&#xff0c;就像蚂蚁在晕头转向的情况下&#xff0c;每次都沿随机方向前行路径。 在自然界&#xff0c;物理学&#xff0c;生物学&#xff0…

【Linux】Job for network.service failed(网卡启动报错)

上图是Linux网卡启动报错的情况 这是由于cat/etc/sysconfig/network-scripts/ifcfg-xxx 中HWADDR的MAC地址和ifconfig中的MAC地址不一样&#xff0c;或者缺少cat/etc/sysconfig/network-scripts/ifcfg-xxx 中HWADDR的MAC地址 1.查看ifconfig中的MAC地址 图中00&#xff1a;0c…

【新星计划-2023】IP地址是什么?IP地址的主要功能是什么?

IP地址在生活中是很常见的&#xff0c;我们所使用的手机、电脑等等&#xff0c;都有一个IP地址&#xff0c;那么IP地址是什么&#xff1f;通过IP地址又能干什么&#xff1f;下文就来给大家详细的讲解一下。 一、什么是IP地址 通常我们说的IP地址多数是指互联网中联网的IP地址…

Java 基础进阶篇(十一)—— Arrays 与 Collections 工具类

文章目录 一、Arrays工具类1.1 Arrays 类常用方法1.2 对于 Comparator 比较器的支持1.3 Arrays 的综合应用1.3.1 应用一&#xff1a;数组的降序排序1.3.2 应用二&#xff1a;根据学生年龄进行排序 二、Collections工具类2.1 Collections 类常用方法2.2 Collections 排序相关 AP…