MySQL数据管理 - 查询语句

文章目录

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

查询数据

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

参考数据表

1 查询指定列

查询所有列

sql 复制代码
SELECT * FROM users;

查询指定的列

sql 复制代码
SELECT username FROM users;

查询指定列,并制定别名

sql 复制代码
SELECT username AS name FROM users;

查询列中的不同的值

sql 复制代码
SELECT DISTINCT username AS name FROM users;

2 条件查询

使用WHERE进行条件查询

sql 复制代码
SELECT * FROM users WHERE id = 1;

逻辑

sql 复制代码
SELECT * FROM users WHERE id = 1 OR id = 3;
sql 复制代码
SELECT * FROM users WHERE username = 'zhangsan' AND password = '123456';

查询不为NULL的情况

sql 复制代码
SELECT * FROM users WHERE birthday is NOT NULL;

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

查询数值范围

sql 复制代码
SELECT * FROM users WHERE id BETWEEN 1 AND 5; 

3 合并查询

合并字符串

sql 复制代码
SELECT CONCAT(username, ' ', password) as userpasswd FROM users WHERE id BETWEEN 1 AND 5;

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

4 模糊查询

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

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

查询姓zhang的人

sql 复制代码
SELECT * FROM users WHERE username LIKE 'zhang%';

5 聚合函数查询

查询所有数据的调试

sql 复制代码
SELECT COUNT(*) FROM users;

查询某一列有值的函数

sql 复制代码
SELECT COUNT(birthday) FROM users;

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

sql 复制代码
SELECT AVG(value_1) FROM users;
sql 复制代码
SELECT MAX(value_1) FROM users;
sql 复制代码
SELECT MIN(value_1) FROM users;
sql 复制代码
SELECT SUM(value_1) FROM users;

6 对值进行排序

升序

sql 复制代码
SELECT * FROM users ORDER BY id ASC;

降序

sql 复制代码
SELECT * FROM users ORDER BY id DESC;

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

sql 复制代码
SELECT * FROM users ORDER BY id ASC, phone_number DESC;

7 分组查询

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

sql 复制代码
SELECT username, count(*), AVG(value_1) FROM users GROUP BY username;

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

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

sql 复制代码
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进行过滤

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

8 分页查询

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

sql 复制代码
SELECT * FROM users LIMIT 1, 5;

9 数据库关联查询

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

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

1 内连接 INNER JOIN

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

使用INNER JOIN

sql 复制代码
SELECT * FROM worker INNER JOIN work ON worker.worker_id = work.worker_id INNER JOIN repository ON repository.repo_id = work.repo_id ;

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

sql 复制代码
SELECT * FROM worker, work, repository WHERE worker.worker_id = work.work_id AND repository.repo_id = work.repo_id ;

2 LEFT JOIN

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

sql 复制代码
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

sql 复制代码
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

删除呢?

sql 复制代码
DELETE FROM users WHERE id IN (SELECT id FROM users WHERE id BETWEEN 1 AND 3);

同样报这个错误

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

sql 复制代码
SELECT worker_name FROM worker WHERE worker.worker_id IN (SELECT worker_id FROM work);

参考

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

相关推荐
生信摆渡16 分钟前
R语言-快速对多个变量取交集
开发语言·数据库·r语言
虚拟网络工程师41 分钟前
【网络系统管理】Centos7——配置主从mariadb服务器案例(下半部分)
运维·服务器·网络·数据库·mariadb
福如意如我心意1 小时前
PostGres命令【常用维护,增删改查】
数据库·postgresql·psql
计算机毕设源码qq-38365310411 小时前
(附项目源码)Java开发语言,215 springboot 大学生爱心互助代购网站,计算机毕设程序开发+文案(LW+PPT)
java·开发语言·spring boot·mysql·课程设计
袁庭新1 小时前
Cannal实现MySQL主从同步环境搭建
java·数据库·mysql·计算机·java程序员·袁庭新
爱学习的白杨树1 小时前
MySQL中有哪几种锁?
数据库·mysql
007php0071 小时前
GoZero 上传文件File到阿里云 OSS 报错及优化方案
服务器·开发语言·数据库·python·阿里云·架构·golang
晴天飛 雪1 小时前
Grafana监控PostgreSQL
数据库·postgresql·grafana
斗-匕1 小时前
Spring事务管理
数据库·spring·oracle
一行玩python2 小时前
SQLAlchemy,ORM的Python标杆!
开发语言·数据库·python·oracle