MYSQL——数据处理之查询

一、基本SELECT语句

SELECT *|{[DISTINCT] column|expression}
FROM table;

#SELECT 标识选择哪些列
#FROM 表示从哪个表中选择
SELECT *     #*表示选择全部列
FROM departments;


SELECT department_id,location_id       #选择特定的列
FROM departments;

SQL语言大小写不敏感,SQL可以写在一行或者多行,关键字不能被缩写也不能分行,各子句一般要分行写。使用缩进提高语句的可读性。
日期和字符只能在单引号中出现

列的别名:重命名一个列,能便于计算。

SELECT first_name AS "名字",salary "工资"      #去掉AS也可以 取别名
FROM employees;

在这里插入图片描述
使用DESCRIBE命令,显示表结构:

DESCRIBE employees

在这里插入图片描述

二、过滤和排序数据

使用WHERE子句,将不满足条件的行过滤,WHERE子句紧跟随FROM子句。

SELECT *|{[DISTINCT] column|expression[alias],...}
FROM table
[WHERE condition(s)];

在这里插入图片描述
其中还有一个不常用的<=>符号,表示可能等于,虽然可以用,但不推荐,通常使用<=> null

SELECT last_name,salary
FROM empoyees
WHERE salary <=3000;

在这里插入图片描述
(1)BETWEEN…AND…的用法

SELECT last_name,salary
FROM employees
WHERE salary BETWEEN 2500 AND 3500;

在这里插入图片描述
(2)IN的用法

SELECT employee_id,last_name,salary,manager_id
FROM employees
WHERE manager_id IN(100,101,201);

在这里插入图片描述
(3)LIKE的用法

SELECT first_name
FROM employees
WHERE first_name LIKE 'S%';

在这里插入图片描述
(4)NULL的用法

SELECT last_name,manager_id
FROM employees
WHERE manager_id IS NULL;

在这里插入图片描述
在这里插入图片描述
(5)AND的用法

SELECT employee_id,last_name,job_id,salary
FROM employees
WHERE salary >=100
AND job_id LIKE '%MAN%';

在这里插入图片描述
(6)OR的用法

SELECT employee_id,last_name,job_id,salary
FROM employees
WHERE salary >= 10000
OR job_id LIKE '%MAN%';

在这里插入图片描述
(7)NOT的用法

SELECT last_name,job_id
FROM employees
WHERE job_id
   NOT IN ('IT_PROG','ST_CLERK','SA_REP');

在这里插入图片描述
(8)ORDER BY子句

ASC(ascend):升序
DESC(descend):降序

SELECT last_name,job_id,department_id,hire_date
FROM employees
ORDER BY hire_date;         #默认是升序,若想要改为降序则为ORDER BY hire_date DESC;

在这里插入图片描述
(9)按别名排序

SELECT employee_id,last_name,salary*12 AS annsal
FROM employees
ORDER BY annsal;

在这里插入图片描述
(10)多个列排序

SELECT last_name,department_id,salary
FROM employees
ORDER BY department_id,salary DESC;

在这里插入图片描述

三、分组函数

定义:分组函数作用于一组数据,并对一组数据返回一个值。
在这里插入图片描述

函数类型:

AVG() ——求平均
COUNT() ——计数
MAX() ——最大值
MIN() ——最小值
SUM() ——求和

函数语法:

SELECT [column,] group_function(column), ...
FROM table
[WHERE condition]
[GROUP BY column]
[ORDER BY column];

(1)AVG(平均值)和 SUM (合计)函数:
可以对数值型数据使用AVG 和 SUM 函数

SELECT AVG(salary), MAX(salary),
MIN(salary), SUM(salary)
FROM employees
WHERE job_id LIKE '%REP%';

在这里插入图片描述
(2)MIN(最小值)和 MAX(最大值)函数
可以对任意数据类型的数据使用 MIN 和 MAX 函数

SELECT MIN(hire_date), MAX(hire_date)
FROM employees;

在这里插入图片描述
(3)COUNT(计数)函数

COUNT(*) 返回表中记录总数,适用于任意数据类型

SELECT COUNT(*)
FROM employees
WHERE department_id = 50;

在这里插入图片描述
COUNT(expr) 返回expr不为空的记录总数

SELECT COUNT(commission_pct)
FROM employees
WHERE department_id = 50;

在这里插入图片描述

四、分组查询

在这里插入图片描述
(1)GROUP BY 子句语法:

可以使用GROUP BY子句将表中的数据分成若干组

SELECT column, group_function(column)
FROM table
[WHERE condition]
[GROUP BY group_by_expression]
[ORDER BY column];

注意:WHERE一定放在FROM后面

在SELECT 列表中所有未包含在组函数中的列都应该包含在 GROUP BY 子句中。

SELECT department_id, AVG(salary)
FROM employees
GROUP BY department_id ;

在这里插入图片描述
包含在 GROUP BY 子句中的列不必包含在SELECT 列表中:

SELECT AVG(salary)
FROM employees
GROUP BY department_id ;

在这里插入图片描述
(2)使用多个列分组在这里插入图片描述
在GROUP BY子句中包含多个列:

SELECT department_id dept_id, job_id, SUM(salary)
FROM employees
GROUP BY department_id, job_id ;

在这里插入图片描述
(3)非法使用组函数

• 不能在 WHERE 子句中使用组函数。
• 可以在 HAVING 子句中使用组函数。

SELECT department_id, AVG(salary)
FROM employees
WHERE AVG(salary) > 8000
GROUP BY department_id;

在这里插入图片描述

注意:WHERE 子句中不能使用组函数

(4)过滤分组在这里插入图片描述
使用 HAVING 过滤分组:

  1. 行已经被分组
  2. 使用了组函数
  3. 满足HAVING 子句中条件的分组将被显示
#语法:

SELECT column, group_function
FROM table
[WHERE condition]
[GROUP BY group_by_expression]
[HAVING group_condition]
[ORDER BY column];
SELECT department_id, MAX(salary)
FROM employees
GROUP BY department_id
HAVING MAX(salary)>10000 ;

在这里插入图片描述

五、多表查询

在这里插入图片描述
案例:查询女神名称和对应男神名称

语法:select name,boyName from beauty,boys;
在这里插入图片描述

笛卡尔集的错误情况:
select count(*) from beauty;
假设输出12select count(*)from boys;
假设输出4行
最终结果:12*4=48

笛卡尔集会在下面条件下产生:

– 省略连接条件
– 连接条件无效
– 所有表中的所有行互相连接

为了避免笛卡尔集, 可以在 WHERE 加入有效的连接条件。

(1)Mysql 连接
使用连接在多个表中查询数据

SELECT table1.column, table2.column
FROM table1, table2
WHERE table1.column1 = table2.column2;

在 WHERE 子句中写入连接条件
在表中有相同列时,在列名之前加上表名前缀

在这里插入图片描述
(2)等值连接

SELECT beauty.id,NAME,boyname FROM beauty ,boys
WHERE beauty.`boyfriend_id`=boys.id;

在这里插入图片描述
(3)区分重复的列名

使用表名前缀在多个表中区分相同的列
• 在不同表中具有相同列名的列可以用表的别名 加以区分
• 如果使用了表别名,则在select语句中需要使 用表别名代替表名
• 表别名最多支持32个字符长度,但建议越少越 好

(4)表的别名

优点:

• 使用别名可以简化查询。
• 使用表名前缀可以提高执行效率。

SELECT bt.id,NAME,boyname
FROM beauty bt,boys b;
WHERE bt.`boyfriend_id`=b.id ;

在这里插入图片描述
(5)连接多个表
在这里插入图片描述

连接 n个表,至少需要 n-1个连接条件

例如:连接 三个表,至少需要两个连接条件。

(6)SQL99:使用ON 子句创建连接

• 自然连接中是以具有相同名字的列为连接条件的。
• 可以使用 ON 子句指定额外的连接条件。
• 这个连接条件是与其它条件分开的。
•ON 子句使语句具有更高的易读性。

(7)join连接

分类:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

(8)ON子句

SELECT bt.id,NAME,boyname
FROM beauty bt
Inner join boys b
On bt.`boyfriend_id`=b.id ;

在这里插入图片描述

六、分页查询

(1)imit 基本实现方式

一般情况下,客户端通过传递 pageNo(页码)、pageSize(每页条数)两个参数去分页查询数据库中的数据,在数据量较小(元组百/千级)时使用 MySQL自带的 limit 来解决这个问题:
在这里插入图片描述
(2)eg.从id开始的10条数据
在这里插入图片描述
(3)建立主键或者唯一索引

在数据量较小的时候简单的使用 limit 进行数据分页在性能上面不会有明显的缓慢,但是数据量达到了 万级到百万级 sql语句的性能将会影响数据的返回。这时需要利用主键或者唯一索引进行数据分页;
在这里插入图片描述
(4)基于数据再排序

当需要返回的信息为顺序或者倒序时,对上面的语句基于数据再排序。order by ASC/DESC 顺序或倒序 默认为顺序
在这里插入图片描述

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值