DQL查询

DQL:针对数据表中的记录进行查询

目录

一、基础查询

1、查询表中所有列数据

2、查询表中指定列的数据

3、别名查询

4、清除重复值

5、查询结果参与运算

二、蠕虫复制

三、条件查询

四、模糊查询

五、排序查询

六、聚合查询

七、分组查询

八、分页查询


一、基础查询

1、查询表中所有列数据

①写出每列的名称

SELECT 字段名1, 字段名2, ... FROM 表名;

②使用*表示所有列

SELECT * FROM 表名;

2、查询表中指定列的数据

#SELECT 字段名1, 字段名2 FROM 表名;
select id,name from student;

3、别名查询

查询sudent表中name 和 age 列,name列的别名为”姓名”,age列的别名为”年龄”

select name as 姓名 ,age as 年龄 from student;

4、清除重复值

查询指定列并且结果不出现重复数据

# SELECT DISTINCT 字段名,字段名,.. FROM 表名;
select distinct age from student;

5、查询结果参与运算

①某列数据和固定值运算

SELECT 列名1 + 固定值 FROM 表名;

②某列数据和其他列数据参与运算

SELECT 列名1 + 列名2 FROM 表名;

注意: 参与运算的必须是数值类型

eg:查询math + english的和使用别名”总成绩”

select math+english  as 总成绩 from student;

查询所有列与math + english的和并使用别名”总成绩”

select *,math+english  as 总成绩 from student;

二、蠕虫复制

什么是蠕虫复制:在已有的数据基础之上,将原来的数据进行复制,插入到对应的表中

语法格式:

insert into 表名1 select * from 表名2

eg:

  • 创建student2表,student2结构和student表结构一样
create table student2 like student;
  • 将student表中的数据添加到student2表中

insert into student2 select * from student;

如果只想复制student表中name,age字段数据到student2表中使用如下格式  

insert into student2(name, age) SELECT name, age FROM student;

三、条件查询

语法格式:

SELECT 字段名... FROM 表名 WHERE 条件;

①比较运算符

>大于

<小于

<=小于等于

>=大于等于

=等于

<>!=不等于

②逻辑运算符

and(&&) 多个条件同时满足 一假即假

or(||) 多个条件其中一个满足 一真即真

not(!) 不满足 取反

③in关键字

语法格式:

SELECT * FROM 表名 WHERE 字段 in (值1, 值2, 值3);

in里面的每个数据都会作为一次条件,只要满足条件的就会显示

eg:

  • 查询id是1或3或5的学生

SELECT * FROM student3 WHERE id IN (1,3,5);
  • 查询id不是1或3或5的学生

​​​​​​​

SELECT * FROM student3 WHERE id NOT IN (1,3,5);

④范围

BETWEEN 值1 AND 值2 -- 表示从值1到值2范围,包头又包尾

比如:age BETWEEN 80 AND 100 相当于: age>=80 && age<=100

四、模糊查询

LIKE表示模糊查询

SELECT * FROM 表名 WHERE 字段名 LIKE '通配符字符串';

满足通配符字符串规则的数据就会显示出来 ,所谓的通配符字符串就是含有通配符的字符串 MySQL通配符有两个: %: 表示零个一个多个字符(任意多个字符) _: 表示一个字符

​​​​​​​

例如:  name like '张%' 所有姓张学员。 

name like '%张%' 名字里只要有张就可以。

name like '张_' 所有姓张名字为两个字学员。

name like '_张_'  只有中间是张,前面一个字,后面一个字。

五、排序查询

①单列排序:单列排序就是使用一个字段排序

语法格式:

 SELECT 字段 FROM 表名 ORDER BY 排序的字段 [ASC|DESC];

ASC: 升序排序(默认) DESC: 降序排序


#按照数学成绩降序排序
select * from student3 order by math desc ;

②组合排序:组合排序就是先按第一个字段进行排序,如果第一个字段相同,才按第二个字段进行排序,依次类推。

SELECT 字段名 FROM 表名 WHERE 字段=值 ORDER BY 字段名1 [ASC|DESC], 字段名2 [ASC|DESC];

六、聚合查询

五个聚合函数:

SUM(列名)求和
count(列名)统计数量 根据列统计行数
max(列名)最大值
min(列名)最小值
avg(列名)平均值

​​​​​​​

SELECT 聚合函数(字段) FROM 表名;

统计数量常用:

SELECT COUNT(*) FROM student3;

统计数学与英语的总和值。

-- 统计数学与英语的总和值
select sum(math) + sum(english) from student3;
-- 或者是
select sum(math + english) from student3;

我们发现按照方法二的做法,结果是有问题的。结果少了86。

产生问题的原因:

上述写法会先将每一行的数学分数值和英语分数值进行相加,然后再把每一行的数学分数值和英语分数值相加后的值进行求和。

这样写会出现一个问题,因为在mysql中null值和任何值相加为null,导致在进行柳青的数学和英语相加的时候,柳青的数学和英语和值就变为了null。而最后sum求和的时候,就把柳青的数学和英语和值null给排除,因此最后的和值会缺少柳青的数学和英语和值86。

解决方案:在sql语句中我们可以使用数据库提供的函数ifnull(列名, 默认值)来解决上述问题。

ifnull(列名, 默认值)函数表示判断该列名是否为null,如果为null,返回默认值,如果不为null,返回实际的值。

例子:

english 的值是null

ifnull(english,2) ====english列的值是null,返回值是 2

english的值是3

ifnull(english,2) ===== english列的值不是null,返回实际值是3

​​​​​​​​​​​​​​

​​​​​​​
select sum(ifnull(english,0)+ifnull(math,0)) from student3;

七、分组查询

分组其实就是按列进行分类,然后可以对分类完的数据使用聚合函数进行运算。

注意:分组有一个特点:

一旦使用了分组函数,那么最终在显示的时候,只能显示被分组的列或者聚合函数

错误写法:

select product ,id from orders group by product;

因为id并没有在group by后面。

如果分组之后,还需要一些条件。

可以使用having条件,表示分组之后的条件,在having后面可以书写聚合函数。

having必须和group by 一起使用,having和where的用法一模一样

但是where后面不可以使用聚合函数,但是在having后面是可以使用聚合函数的。

where 和 having 的区别。

1、having 通常与group by 分组结合使用。 where 和分组无关。

2、having 可以书写聚合函数 (聚合函数出现的位置: having 之后)

 3、where 是在分组之前进行过滤的。having 是在分组之后进行过滤的。

例如having中的 聚合函数(count,sum,avg,max,min),是不可以出现where条件中。

eg:根据商品名(product)分组,显示商品总价大于10的商品

select product ,sum(price) from orders group by product having sum(price)>10;

分组查询的用法实例:

 

​​​​​​

八、分页查询

语法:

select 字段列表 from 表 limit 起始索引,查询条数
/*分页查询:
SELECT字段列表FROM表名 LIMIT起始索引,查询条目数
★起始索引:从0开始
*/
-- 从0开始查询,每页查3条数据
select *
from stu
limit 0,3;

-- 从0开始查询,每页查3条数据,查询第一页数据
select *
from stu
limit 0,3;
-- 从0开始查询,每页查3条数据,查询第二页数据
select *
from stu
limit 3,3;
-- 从0开始查询,每页查3条数据,查询第三页数据
select *
from stu
limit 6,3;

 注意:起始索引=(当前页码- 1)*每页显示的条数(常用于开发中计算起始索引)

比如:

SQL语句的执行流顺序

SQL完整语句:select 字段列表 from 表名 where 条件 group by 分组字段 having 分组后条件 order by 排序字段 limit 起始索引,条数

执行顺序:1、from  2、where 3、group by 4、having 5、select 6、order by 7、limit

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值