MySQL 实验 9:数据查询(2)—— 条件查询

news2024/10/7 15:27:59

MySQL 实验 9:数据查询(2)—— 条件查询

目录

  • MySQL 实验 9:数据查询(2)—— 条件查询
    • 一、查询用到的运算符
          • 1、比较运算符
        • 2、逻辑运算符
    • 二、比较运算符的应用举例
    • 三、逻辑运算符的应用举例
    • 四、运算符 BETWEEN … AND 的用法
    • 五、运算符 IN 的用法
    • 六、运算符 IS NULL 的用法
    • 七、使用通配符查询
        • 1、百分号( % )的用法
      • 2、下划线( _ )的用法

查询中可以使用 WHERE 关键字来指定查询条件,从数据表中查询出满足某个条件的数据。

注意:由于 WHERE 关键字先于 SELECT 关键字执行,因此条件中不能使用关键字 SELECT 后面的别名,但可以使用表的别名。

一、查询用到的运算符

可以使用比较运算符和逻辑运算符构造查询条件。

1、比较运算符

比较运算符可以对两个数据的值进行比较,常用的比较运算符如下:

等于:=
大于:>
大于或等于:>=
小于:<
小于或等于:<=
不等于:!=(<>)
在某个范围内:BETWEENAND
在某个集合内:IN
为空值:IS NULL
使用通配符查询:LIKE
2、逻辑运算符

逻辑运算符包括 NOT(或:!)、AND 和 OR,是对多个查询条件进行运算,用于构造复杂的查询条件。用法如下:

-- 对条件1求反,如果条件1为真,结果为假;如果条件1为假,则结果为真
NOT 条件1	

-- 如果条件1和条件2都为真,结果为真
条件1 AND 条件2	

-- 条件1和条件2有一个为真,结果为真
条件1 OR 条件2	

二、比较运算符的应用举例

(1)查询 dept_id 为【D01】的学生信息

mysql> select * from stu where dept_id='D01';
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124001 | 薛智玲 || 2000-01-15 | 13637358097 | D01     |
| 20220124002 | 杨铭华 || 2001-03-06 | 13637381407 | D01     |
| 20220124003 | 张从超 || 2003-12-09 | 13637389129 | D01     |
| 20220124004 | 孙金航 || 2003-03-07 | 13637387244 | D01     |
+-------------+--------+--------+------------+-------------+---------+
4 rows in set (0.01 sec)

(2)查询 2003 年 3 月 7 日(含 2003 年 3 月 7 日)以后出生的学生信息

mysql> select * from stu where birth>='2003-3-7';
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124003 | 张从超 || 2003-12-09 | 13637389129 | D01     |
| 20220124004 | 孙金航 || 2003-03-07 | 13637387244 | D01     |
| 20220214003 | 裴天馨 || 2003-04-15 | 13637381374 | D02     |
| 20220325101 | 董雯林 || 2003-12-27 | 13637357085 | D03     |
+-------------+--------+--------+------------+-------------+---------+
4 rows in set (0.00 sec)

三、逻辑运算符的应用举例

(1)查询 2003 年 3 月 7 日(含 2003 年 3 月 7 日)之前出生的【男生】的信息

mysql> select * from stu where birth<='2003-3-7' and gender='男';
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124001 | 薛智玲 || 2000-01-15 | 13637358097 | D01     |
| 20220124002 | 杨铭华 || 2001-03-06 | 13637381407 | D01     |
| 20220214001 | 谭宝名 || 2002-08-05 | 13637332439 | D02     |
| 20220325102 | 周宜可 || 2002-07-04 | 13637333898 | D03     |
| 20220325103 | 张春晶 || 2001-06-21 | 13637340698 | D03     |
| 20220410102 | 聂小龙 || 2002-12-04 | 13637331432 | D04     |
| 20220410104 | 江沐洪 || 2002-02-12 | 13637345052 | NULL    |
+-------------+--------+--------+------------+-------------+---------+
7 rows in set (0.00 sec)

(2)查询 dept_id 为【D01】或【D03】的学生信息

mysql> select * from stu where dept_id='D01' or dept_id='D03';
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124001 | 薛智玲 || 2000-01-15 | 13637358097 | D01     |
| 20220124002 | 杨铭华 || 2001-03-06 | 13637381407 | D01     |
| 20220124003 | 张从超 || 2003-12-09 | 13637389129 | D01     |
| 20220124004 | 孙金航 || 2003-03-07 | 13637387244 | D01     |
| 20220325101 | 董雯林 || 2003-12-27 | 13637357085 | D03     |
| 20220325102 | 周宜可 || 2002-07-04 | 13637333898 | D03     |
| 20220325103 | 张春晶 || 2001-06-21 | 13637340698 | D03     |
+-------------+--------+--------+------------+-------------+---------+
7 rows in set (0.00 sec)

四、运算符 BETWEEN … AND 的用法

BETWEEN … AND 用来限定查找的信息在两个值(一个表示最小值,一个表示最大值,包含边界)之间。语法格式如下:

-- 查找某个范围之内的记录,格式如下:
where 列名 BETWEEN m AND n    -- 等价于 列名 >= m and 列名 <= n

-- 查找不在某个范围之内的记录,格式如下:
where 列名 NOT BETWEEN m AND n

例如:

(1)查找 2001 年 3 月 6 日(含: 2001 年 3 月 6 日)与 2003 年 3 月 7 日(含 2003 年 3 月 7 日)之间出生的学生信息,查询结果按照 birth 排序。

mysql> select * from stu where birth between '2001-3-6' and '2003-3-7' order by birth;
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124002 | 杨铭华 || 2001-03-06 | 13637381407 | D01     |
| 20220214002 | 赵文瀚 || 2001-03-25 | 13637381710 | D02     |
| 20220325103 | 张春晶 || 2001-06-21 | 13637340698 | D03     |
| 20220410104 | 江沐洪 || 2002-02-12 | 13637345052 | NULL    |
| 20220410103 | 赵晨祥 || 2002-05-22 | 13637388564 | D04     |
| 20220325102 | 周宜可 || 2002-07-04 | 13637333898 | D03     |
| 20220214001 | 谭宝名 || 2002-08-05 | 13637332439 | D02     |
| 20220410101 | 夏飞研 || 2002-09-02 | 13637326693 | D04     |
| 20220410102 | 聂小龙 || 2002-12-04 | 13637331432 | D04     |
| 20220124004 | 孙金航 || 2003-03-07 | 13637387244 | D01     |
+-------------+--------+--------+------------+-------------+---------+
10 rows in set (0.00 sec)

(2)查找不在 2001 年 3 月 6 日与 2003 年 3 月 7 日之间出生的学生信息,查询结果按照 birth 排序。

mysql> select * from stu where birth not between '2001-3-6' and '2003-3-7' order by birth;
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124001 | 薛智玲 || 2000-01-15 | 13637358097 | D01     |
| 20220214003 | 裴天馨 || 2003-04-15 | 13637381374 | D02     |
| 20220124003 | 张从超 || 2003-12-09 | 13637389129 | D01     |
| 20220325101 | 董雯林 || 2003-12-27 | 13637357085 | D03     |
+-------------+--------+--------+------------+-------------+---------+
4 rows in set (0.00 sec)

五、运算符 IN 的用法

使用 IN 操作符,表示要查询的数据在一个集合内,IN 操作符可以部分代替逻辑表达式 OR。语法格式如下:

WHERE 列名 [NOT] IN (数据1, 数据2, ...)

WHERE 列名 [NOT] IN (select 子查询)

例如:

(1)查询 dept_id 为【D01】或【D03】的学生信息

mysql> select * from stu where dept_id in ('D01','D03');
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124001 | 薛智玲 || 2000-01-15 | 13637358097 | D01     |
| 20220124002 | 杨铭华 || 2001-03-06 | 13637381407 | D01     |
| 20220124003 | 张从超 || 2003-12-09 | 13637389129 | D01     |
| 20220124004 | 孙金航 || 2003-03-07 | 13637387244 | D01     |
| 20220325101 | 董雯林 || 2003-12-27 | 13637357085 | D03     |
| 20220325102 | 周宜可 || 2002-07-04 | 13637333898 | D03     |
| 20220325103 | 张春晶 || 2001-06-21 | 13637340698 | D03     |
+-------------+--------+--------+------------+-------------+---------+
7 rows in set (0.00 sec)

(2)查询 dept_id 不是【D01】或【D03】的学生信息

mysql> select * from stu where dept_id not in ('D01','D03');
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220214001 | 谭宝名 || 2002-08-05 | 13637332439 | D02     |
| 20220214002 | 赵文瀚 || 2001-03-25 | 13637381710 | D02     |
| 20220214003 | 裴天馨 || 2003-04-15 | 13637381374 | D02     |
| 20220410101 | 夏飞研 || 2002-09-02 | 13637326693 | D04     |
| 20220410102 | 聂小龙 || 2002-12-04 | 13637331432 | D04     |
| 20220410103 | 赵晨祥 || 2002-05-22 | 13637388564 | D04     |
| 20220410104 | 江沐洪 || 2002-02-12 | 13637345052 | NULL    |
+-------------+--------+--------+------------+-------------+---------+
7 rows in set (0.00 sec)

六、运算符 IS NULL 的用法

使用 IS NULL 可以查询某个列为空的记录。查询某个列为空值的记录不能使用等号(因为 NULL 和任何值用 = 比较结果为 NULL),需要使用 IS NULL。语法格式如下:

-- 查询某个列为空的记录
where 列名 IS NULL

-- 查询某个列不为空的记录
where 列名 IS NOT NULL

例如:

(1)查询 dept_id 为空的学生信息

mysql> select * from stu where dept_id is null;
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220410104 | 江沐洪 || 2002-02-12 | 13637345052 | NULL    |
+-------------+--------+--------+------------+-------------+---------+
1 row in set (0.00 sec)

(2)查询 dept_id 不为空的学生信息

mysql> select * from stu where dept_id is not null;
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124001 | 薛智玲 || 2000-01-15 | 13637358097 | D01     |
| 20220124002 | 杨铭华 || 2001-03-06 | 13637381407 | D01     |
| 20220124003 | 张从超 || 2003-12-09 | 13637389129 | D01     |
| 20220124004 | 孙金航 || 2003-03-07 | 13637387244 | D01     |
| 20220214001 | 谭宝名 || 2002-08-05 | 13637332439 | D02     |
| 20220214002 | 赵文瀚 || 2001-03-25 | 13637381710 | D02     |
| 20220214003 | 裴天馨 || 2003-04-15 | 13637381374 | D02     |
| 20220325101 | 董雯林 || 2003-12-27 | 13637357085 | D03     |
| 20220325102 | 周宜可 || 2002-07-04 | 13637333898 | D03     |
| 20220325103 | 张春晶 || 2001-06-21 | 13637340698 | D03     |
| 20220410101 | 夏飞研 || 2002-09-02 | 13637326693 | D04     |
| 20220410102 | 聂小龙 || 2002-12-04 | 13637331432 | D04     |
| 20220410103 | 赵晨祥 || 2002-05-22 | 13637388564 | D04     |
+-------------+--------+--------+------------+-------------+---------+
13 rows in set (0.00 sec)

七、使用通配符查询

在查询数据时,通配符可以替代指定位置的一个(下划线:_)或多个字符(百分号:%)。MySQL 可使用如下所示的通配符:

百分号( % ):表示在百分号( % )位置可以有任意个字符,字符内容不限
下划线( _ ):表示在下划线( _ )位置有且只有一个字符,字符内容不限

说明:
(1)如果条件中使用了通配符,比较运算符必须使用 LIKE,而不能使用 =、>、< 等运算符。如果比较运算符不使用 LIKE,则 MySQL 认为百分号和下划线就是普通字符,而不是通配符。
(2)如果条件中使用了通配符,查询时如果通配符放在最左边,则不会使用索引。

1、百分号( % )的用法

查询时表示在该位置可以是任意个(0 - n 个)字符,字符的内容不限。例如:

(1)查询姓【张】的学生信息。

mysql> select * from stu where s_name like '张%';
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124003 | 张从超 || 2003-12-09 | 13637389129 | D01     |
| 20220325103 | 张春晶 || 2001-06-21 | 13637340698 | D03     |
+-------------+--------+--------+------------+-------------+---------+
2 rows in set (0.00 sec)

(2)查询姓名最后一个字是【超】的学生信息

mysql> select * from stu where s_name like '%超';
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124003 | 张从超 || 2003-12-09 | 13637389129 | D01     |
+-------------+--------+--------+------------+-------------+---------+
1 row in set (0.00 sec)

(3)查询姓名中包含【飞】字的学生信息。

mysql> select * from stu where s_name like '%飞%';
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220410101 | 夏飞研 || 2002-09-02 | 13637326693 | D04     |
+-------------+--------+--------+------------+-------------+---------+
1 row in set (0.00 sec)

2、下划线( _ )的用法

查询时表示在该位置有且只有一个字符,字符的内容不限。必须和 LIKE 运算符一起使用。例如:

(1)查询 phone 中倒数第三是 0 的学生信息

mysql> select * from stu where phone like '%0__';   -- 两个下划线
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124001 | 薛智玲 || 2000-01-15 | 13637358097 | D01     |
| 20220325101 | 董雯林 || 2003-12-27 | 13637357085 | D03     |
| 20220410104 | 江沐洪 || 2002-02-12 | 13637345052 | NULL    |
+-------------+--------+--------+------------+-------------+---------+
3 rows in set (0.00 sec)

(2)查询 phone 中第四位至第七位为 3738 的学生信息

mysql> select * from stu where phone like '___3738%';  -- 三个下划线
+-------------+--------+--------+------------+-------------+---------+
| s_id        | s_name | gender | birth      | phone       | dept_id |
+-------------+--------+--------+------------+-------------+---------+
| 20220124002 | 杨铭华 || 2001-03-06 | 13637381407 | D01     |
| 20220124003 | 张从超 || 2003-12-09 | 13637389129 | D01     |
| 20220124004 | 孙金航 || 2003-03-07 | 13637387244 | D01     |
| 20220214002 | 赵文瀚 || 2001-03-25 | 13637381710 | D02     |
| 20220214003 | 裴天馨 || 2003-04-15 | 13637381374 | D02     |
| 20220410103 | 赵晨祥 || 2002-05-22 | 13637388564 | D04     |
+-------------+--------+--------+------------+-------------+---------+
6 rows in set (0.00 sec)

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

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

相关文章

Linux下载安装MySQL8.4

这里写目录标题 一、准备工作查看系统环境查看系统架构卸载已安装的版本 二、下载MySQL安装包官网地址 三、安装过程上传到服务器目录解压缩&#xff0c;设置目录及权限配置my.cnf文件初始化数据库配置MySQL开放端口 一、准备工作 查看系统环境 确认Linux系统的版本和架构&am…

[单master节点k8s部署]31.ceph分布式存储(二)

Ceph配置 Ceph集群通常是一个独立的存储集群&#xff0c;可以部署在 Kubernetes 集群之外。Ceph 提供分布式存储服务&#xff0c;能够通过 RADOS、CephFS、RBD&#xff08;块存储&#xff09;、和 RGW&#xff08;对象存储&#xff09;等方式与 Kubernetes 集成。即使 Ceph 部…

SumatraPDF一打开就无响应怎么办?

结论&#xff1a;当前安装版不论32位还是64位都会出现问题。使用portable免安装版未发现相关问题。——sumatrapdf可以用于pdf, epub, mobi 等格式文件的浏览。 点击看相关问题和讨论

如何使用 Python 的 logging 模块记录日志

如何使用 Python 的 logging 模块记录日志 在编写 Python 程序时&#xff0c;日志记录是一个非常重要的部分。日志不仅帮助你在开发过程中调试代码&#xff0c;还可以在程序正式运行时提供诊断信息&#xff0c;帮助定位问题。如果你正在构建一个复杂的系统或者开发大型应用程序…

【数据结构】【队列】算法汇总

一、顺序队列【相当于一维数组】 1.准备工作 #define MAXQSIZE 100 typedef struct{QElemType*base;int front;int rear; }SqQueue; 2.队满&#xff0c;队空。入队&#xff0c;出队 二、链式队列 1.准备工作 typedef struct Qnode{ElemType data;struct Qnode*next; }Qnod…

深入浅出解析大模型:探索智能体(Agent)

大语言模型 vs 人类 大语言模型很强大&#xff0c;就像人类的大脑一样拥有思考的能力。如果人类只有大脑&#xff0c;没有四肢&#xff0c;没有工具&#xff0c;是没办法与世界互动的。如果我们能给大模型配备上四肢和工具呢&#xff1f;大模型是不是就会打破次元壁&#xff0…

GD32F4xx USB MSC Host调试记录

本文记录GD32F4xx MCU的RTX系统工程内移植USB MSC Host的例程代码,适配自制的电路板,实现向USB内写入数据。有关USB的一些基础信息,可以参考本专栏的另一篇文章《GD32 MCU USB开发学习记录》。 目录 1. USB MSC host 例程1.1、硬件接口2.2、USB msc host 例程2.2.1 工程目录…

dz论坛可可积分商城插件价值399元

界面简洁美观大方&#xff0c;适合各类站点。支持多用户商城&#xff0c;可让商家入驻站点发布商品&#xff0c;亦可站长自己发布商品。支持向商家抽佣抽成功能&#xff0c;可设置商家在成交商品后按一定比例扣除抽成&#xff0c;达到网站盈利目的采用队列技术处理&#xff0c;…

【ubuntu22.04】 搭建自己的镜像站 【harbor】【docker compose】【超详细】

文章目录 什么是 harbor特点主要功能 部署配置 dns初始化下载 dns编辑 named.conf.local编辑 named.conf.options配置正向解析配置反向解析解析扩展 部署 harbor修改配置执行 prepare执行 install.sh查看镜像访问 自制镜像创建镜像仓库上传镜像开始推送拉取镜像 什么是 harbor …

宏队列和微队列

1、javascript是一个单线程语言。 javascript 语言的目的&#xff08;待补充&#xff09; 2、主线程执行完成之后&#xff0c;再执行微队列&#xff0c;微队列执行完成后再执行宏队列 3、promise的构造函数传入的回调函数是同步执行 4、promise的then函数会直接加入微队列&…

Java 中的 LinkedHashMap

让我们从一个简单的 Java 代码片段开始&#xff0c;演示如何在 Java 中创建和使用 LinkedHashMap。 import java.util.LinkedHashMap; public class LinkedHashMapCreation { public static void main(String[] args) { // Create a LinkedHashMap of S…

【AI知识点】批归一化(Batch Normalization)

批归一化&#xff08;Batch Normalization&#xff0c;BN&#xff09; 是一种用于加速神经网络训练并提高模型稳定性的方法&#xff0c;最早由 Sergey Ioffe 和 Christian Szegedy 在 2015 年提出。批归一化通过在每一层对神经网络中的激活值进行标准化&#xff0c;使得每一层的…

半路出家:如何转行成为软件开发者——之找到一份工作

一、前言 一个半路出家的软件开发者&#xff0c;尽管只有短短几年软件开发的相关经验&#xff0c;却可以凭借他在其他领域积累的丰厚经验&#xff0c;最终一举超过单纯拥有更多软件开发经验的同行【有时拥有不同的专业背景&#xff08;甚至是与软件完全不搭界的行业&#xff09…

SpringBoot赋能旅游管理:系统设计与实现

第三章 系统分析 3.1可行性分析 对所有的系统来说&#xff0c;都有可能会受到时间和空间上的制约。所以&#xff0c;我们在设计每一个项目的时候&#xff0c;必须对该系统实行可行性分析&#xff0c;这样不但能够降低项目的危害&#xff0c;还能改降低人力、物力和财力的损耗。…

弱网(不限于 Wi-Fi)环境的传输优化分析

参见 Wi-Fi弱网传输优化不成功有感 早在几年前还做传输优化时&#xff0c;我就非常不赞同在弱网环境激进传输的优化策略&#xff0c;我一直觉得这是在劣化传输&#xff0c;这观点一直影响着我&#xff0c;我也屡次因为这个与经理发生冲突。这观点如下表述&#xff1a; 弱网环…

【SpringSecurity】基本流程

【中文文档: Spring Security 中文文档 :: Spring Security Reference】 【英文文档&#xff1a;Spring Security】 以下内容只是记录springsecurity最简单的一种验证流程&#xff0c;所有配置基本都是默认的配置。 引入依赖 <dependency><groupId>org.springf…

GPU Puzzles讲解(一)

GPU-Puzzles项目可以让你学习到GPU编程和cuda核心并行编程的概念&#xff0c;通过一个个小问题让你理解cuda的编程和调用&#xff0c;创建共享显存空间&#xff0c;实现卷积和矩阵乘法等&#xff0c;通过每个小问题之后还会奖励一个狗狗小视频&#x1f601; 下面是项目的仓库&…

大模型面试宝典:问题全集及权威解答

导读 自ChatGPT开启大模型时代以来&#xff0c;大模型正迎来飞速发展&#xff0c;现在从事大模型开发相关工作可谓是处在时代的风口。那么大模型面试需要哪些技能和技巧呢&#xff0c;本文详细整理了全套的面试问题及答案&#xff0c;希望对大家有所帮助&#xff01; 目录 [x…

脉冲神经网络(SNN)论文阅读(六)-----ECCV-2024 脉冲驱动的SNN目标检测框架:SpikeYOLO

原文链接&#xff1a;CSDN-脉冲神经网络&#xff08;SNN&#xff09;论文阅读&#xff08;六&#xff09;-----ECCV-2024 脉冲驱动的SNN目标检测框架&#xff1a;SpikeYOLO Integer-Valued Training and Spike-Driven Inference Spiking Neural Network for High-performance …

MySQL数据库专栏(二)SQL语句基础操作

目录 数据库操作 创建数据库 查看数据库 选择数据库 删除数据库 数据表操作 数据表数据类型 数据表列约束 数据表索引 创建表 查看表 查看表结构 删除表 数据表的增删改操作 …