MySQL数据管理 - 查询语句

news/2024/9/25 23:24:57/

文章目录

  • 查询数据
  • 1 查询指定列
  • 2 条件查询
  • 3 合并查询
  • 4 模糊查询
  • 5 聚合函数查询
  • 6 对值进行排序
  • 7 分组查询
  • 8 分页查询
  • 9 数据库关联查询
      • 1 内连接 INNER JOIN
      • 2 LEFT JOIN
      • 3 右连接
  • 10 数据库子查询
  • 参考

查询数据

数据库最常用的操作就是查询,也是数据操作的基础,进行重点学习介绍

参考数据表
在这里插入图片描述

1 查询指定列

查询所有列

SELECT * FROM users;

查询指定的列

SELECT username FROM users;

查询指定列,并制定别名

SELECT username AS name FROM users;

查询列中的不同的值

SELECT DISTINCT username AS name FROM users;

2 条件查询

使用WHERE进行条件查询

SELECT * FROM users WHERE id = 1;

逻辑

SELECT * FROM users WHERE id = 1 OR id = 3;
SELECT * FROM users WHERE username = 'zhangsan' AND password = '123456';

查询不为NULL的情况

SELECT * FROM users WHERE birthday is NOT NULL;

【注意】数据库中不等于不是!=而是<>

查询数值范围

SELECT * FROM users WHERE id BETWEEN 1 AND 5; 

3 合并查询

合并字符串

SELECT CONCAT(username, ' ', password) as userpasswd FROM users WHERE id BETWEEN 1 AND 5;

同样可以不同的运算符对不同列的结果进行操作

4 模糊查询

  • % 代表任意数量的字符
  • _代表单个任意字符

如果要对_进行查询,需要进行转义\_

查询姓zhang的人

SELECT * FROM users WHERE username LIKE 'zhang%';

5 聚合函数查询

查询所有数据的调试

SELECT COUNT(*) FROM users;

查询某一列有值的函数

SELECT COUNT(birthday) FROM users;

求平均值,最大值,最小值,求和,都是对查询的列的值进行运算

SELECT AVG(value_1) FROM users;
SELECT MAX(value_1) FROM users;
SELECT MIN(value_1) FROM users;
SELECT SUM(value_1) FROM users;

6 对值进行排序

升序

SELECT * FROM users ORDER BY id ASC;

降序

SELECT * FROM users ORDER BY id DESC;

多个排序标准,使用, 进行分割

SELECT * FROM users ORDER BY id ASC, phone_number DESC;

7 分组查询

按照列进行分组,使用聚合函数统计每个组中元素的个数

SELECT username, count(*), AVG(value_1) FROM users GROUP BY username;

分组查询一般是对列进行聚合

如果需要对多列进行聚合,此时需要使用合并查询,对不同列的数采取运算操作

SELECT username, AVG(value_1 + value_2)/2 FROM users GROUP BY id;

运行的逻辑,在行上进行相加,然后在列上进行求平均,聚合函数还是聚合的列,聚合函数和分组常常在一起使用

面试题:

数据表为
student
id name chinese math english
1 zhangsan 80 70 65
2 lisi 90 80 72
3 wangwu 98 72 12

请使用SQL查询平均成绩大于60的学生

【注意】对每个学生进行分组查询,使用HAVING进行过滤

SELECT name FROM student GROUP BY id HAVING AVG(chinese + math + english)/3 > 60;

8 分页查询

使用LIMIT指定开始的位置数据的条数

SELECT * FROM users LIMIT 1, 5;

9 数据库关联查询

根据两个表和多个表之间的关系进行查询和展示数据,使用JOIN语句实现

数据库ER图(摆脱了传递函数依赖)

在这里插入图片描述

1 内连接 INNER JOIN

展示仓库和工人的关系,使用了工作关系联结

使用INNER JOIN

SELECT * FROM worker INNER JOIN work ON worker.worker_id = work.worker_id INNER JOIN repository ON repository.repo_id = work.repo_id ;

内连接:也使用等于 = 进行连接

SELECT * FROM worker, work, repository WHERE worker.worker_id = work.work_id AND repository.repo_id = work.repo_id ;

2 LEFT JOIN

左连接允许连接的过程中右表没有匹配的情况

SELECT * FROM worker LEFT JOIN work ON worker.worker_id = work.worker_id LEFT JOIN repository ON worl.repo_id = repository.repo_id;

3 右连接

类似左连接,右连接允许左边的数据为NULL

10 数据库子查询

子查询将一个查询的结果用作数据库语句的条件

将id为1-3的user名字都修改为zhangsan1

UPDATE users SET username='zhangsan1' WHERE id IN (SELECT id FROM users WHERE id BETWEEN 1 AND 3);

报错:SQL Error [1093] [HY000]: You can't specify target table 'users' for update in FROM clause

踩坑:不能先SELECT一个表然后再更新
参考:https://blog.csdn.net/qq_40036754/article/details/115174800

删除呢?

DELETE FROM users WHERE id IN (SELECT id FROM users WHERE id BETWEEN 1 AND 3);

同样报这个错误

在这里插入图片描述

【问题】查询已经管理仓库的工人id;需要注意查询的结果是一行还是多行

SELECT worker_name FROM worker WHERE worker.worker_id IN (SELECT worker_id FROM work);

参考

MYSQL基础 https://www.bilibili.com/video/BV15m421T7RQ


http://www.ppmy.cn/news/1506305.html

相关文章

适用于验证码的OCR,识别快速,使用简单!

环境 windows 11python 3.9 前言 Muggle OCR 是一个高效本地 OCR 模块&#xff0c;旨在通过简单的几步设置提供强大的文本识别功能&#xff0c;无论是在处理印刷文本还是解析验证码&#xff0c;都能让用户在工作中畅通无阻。Muggle OCR 易于安装和使用&#xff0c;支持双模型&a…

02_快速启动 Demo 创建 Electron 项目、electron-forge 搭建一个 electron 项目、手动创建electron项目

快速启动 Demo 创建 Electron 项目 一、克隆一个仓库、快速启动一个项目二、electron-forge 搭建一个 electron 项目三、手动搭建一个 electron 项目四、开发工具中配置 Eslint 一、克隆一个仓库、快速启动一个项目 要使用 git 的话首先电脑上面需要安装 git //克隆示例项目的…

【STM32】USART串口和I2C通信

个人主页~ USART串口和I2C通信 USART串口一、串口1、简介2、电路要求3、参数及时序 二、USART外设1、USART结构2、波特率发生器 三、数据包1、HEX数据包HEX数据包接收 2、文本数据包文本数据包接收 I2C通信一、简介二、通信协议1、硬件电路2、I2C时序基本单元 三、I2C外设1、简…

aop对service下的类方法参数监听打印

平常不发消息&#xff0c;但登录后就会发消息&#xff0c;2个月没登录为了挽留就用before代码&#xff0c;触发消息 登录接口 controller调用service前&#xff0c;打印出方法 步骤&#xff1a; 增加before的注解方法为pointcut的方法&#xff0c; 因为我们要得到controller调…

为什么企业需要安装加密软件

保护敏感数据&#xff1a; 企业通常拥有大量的敏感数据&#xff0c;如客户信息、财务数据、知识产权等。这些数据如果未经保护而被泄露&#xff0c;可能会对企业造成严重的经济损失和声誉损害。加密软件能够对这些敏感数据进行加密&#xff0c;即使数据被窃取&#xff0c;也无…

Lua 脚本编程基础

引言 Lua 是一种轻量级的脚本语言&#xff0c;用标准C编写&#xff0c;设计目的是为了嵌入应用程序中&#xff0c;从而为应用程序提供灵活的扩展和定制功能。由于其简洁和高效&#xff0c;Lua 在游戏开发、嵌入式系统、网络编程等领域得到了广泛应用。 Lua 语言特点 轻量级&…

《Unnatural L0 Sparse Representation for Natural Image Deblurring》

这篇论文的标题是《Unnatural L0 Sparse Representation for Natural Image Deblurring》,作者是Li Xu, Shicheng Zheng, 和 Jiaya Jia,来自香港中文大学。论文主要研究了一种新的图像去模糊方法,这种方法基于L0稀疏表示,旨在提高自然图像去模糊的质量和效率。 链接: l0…

Python的安装环境以及应用

1.环境python2&#xff0c;Python 最新安装3.12可以使用源码安装 查看安装包 [rootpython001 ~]# yum list installed | grep epel 3[rootpython001 ~]# yum list installed | grep python [rootpython001 ~]# yum -y install python3 安装python3 查看版本 [root…