Note/数据库导论/笔记/数据库笔记05——查询数据——2022-03-17.md
2023-08-31 12:43:36 +08:00

616 lines
16 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# 查询数据
## 一、单表查询
### 1.查询所有字段
#### 1在 select 语句中使用 * 查询所有字段
语法select * from 表名;
#### 2在 select 语句中指定所有字段(字段名可以变换顺序)
语法select f_id,s_id,f_name,f_price from fruits;
### 2.查询指定字段
#### 1查询单个字段
语法select f_name from fruits;
#### 2查询多个字段
语法select f_id,s_id,f_name,f_price from fruits;
### 3.查询指定记录where
可以跟 =,>,<,<>,!=,<=,>=,between,and
查询 f_name 是 xxxx 的字段
语法select f_name,f_price from fruits where f_name='xxxx';
查询 f_price 不等于 10.2 的字段
语法select f_name,f_price from fruits where f_price<>10.2;
查询 f_price 在5和10之间的字段
语法select f_name,f_price from fruits where f_price between 5 and 10;**(包含端点值)**
查询 f_price 不在5和10之间的字段
语法select f_name,f_price from fruits where f_price not between 5 and 10;**(不包含端点值)**
### 4.使用in关键字查询
使用 in 关键字将检索条件括起来,检索条件之间用逗号隔开,只需要满足条件范围内一个值即为匹配项。
语法select s_id,f_name,f_price from fruits where s_id in(101,102);
**可以使用关键字 not in 检索不在条件范围内的记录**
语法select s_id,f_name,f_price from fruits where s_id not in(101,103);
### 5.带 like 的字符匹配查询( % _
#### 1%匹配任意长度的字符包括0个字符
以b开头字符查询
语法select f_name,f_price from fruits where f_name like 'b%';
查询水果名中包含p字符的记录
语法select f_name,f_price from fruits where f_name like '%p%';
查询以b开头以y结尾
语法select f_name,f_price from fruits where f_name like 'b%y';
查询以y结尾且y的前面有且仅有4个字母的记录
语法select f_name,f_price from fruits where f_name like '____y';
### 6.查询空值is 【not】null
查询 f_name 为空
语法select f_name,f_price from fruits where f_name is null;
查询 f_name 不为空
语法select f_name,f_price from fruits where f_name is not null;
### 7.带 and 的多条件查询(相当于‘与’,同时满足多个条件)
查询id为101同时价格大于等于5的字段
语法select f_name,f_price from fruits where s_id=101 and f_price>=5;
语法select s_id,f_name,f_price from fruits where s_id=101 and f_price>=5 and f_name like 'a%';
### 8.带 or 的多条件查询(相当于‘或’,满足一个条件即可)
查询i为101或者103的字段
语法select s_id,f_name,f_price from fruits where s_id=101 or s_id=103;
语法select s_id,f_name,f_price from fruits where s_id in(101,103);
这里可以用**in**操作符实现相同功能
**and 的优先级高于 or**
**在实际开发中使用 in 操作符开发语句,更加简单明了,并且 in 执行速度要快于 or ,更重要的是使用 in 操作符,可以执行更加复杂的嵌套查询**
### 9.查询结果不重复distinct
查询 id 不重复
语法select distinct s_id from fruits ;
### 10.对查询结果排序(默认升序【asc】降序【desc】)
#### 1单列排序
升序
语法: select distinct s_id from fruits order by s_id;
降序
语法select distinct s_id from fruits order by s_id desc;
语法select s_id,f_name from fruits order by f_name;
#### 2多列排序
升序
语法select s_id,f_name from fruits order by s_id,f_name;
先按照 s_id 排序, s_id 相同时再按照 s_name 排序
降序
语法select s_id,f_name from fruits order by s_id desc,f_name desc;
### 11.分组查询group by通常和集合函数配合使用
#### 1创建分组
语法select s_id,count(*) from fruits group by s_id;
语法select s_id,count(*) as total from fruits group by s_id;
as 后面是别名
若查看每个供应商提供的水果种类名称可以在group by中使用group_concat()函数,将每个分组中各
个字段的值列举出来例如语法select s_id,group_concat(f_name) from fruits group by s_id;
语法select s_id,group_concat(f_name) as names from fruits group by s_id;
#### 2使用having过滤分组
语法select s_id,group_concat(f_name) as names from fruits group by s_id having count(f_name)>1;、
分组后过滤用having分组前用where进行分组
select s_id,group_concat(f_name) as names from fruits where s_id>=104 group by s_id having count(f_name)>1;
#### 3在group by子句中使用 with rollup
在查出所☐一条记录,该记录出的所有记录的总和
语法: select s_id,count(*) from fruits group by s_id with rollup;
**注意: with rollup和order by不能同时使用互斥**
#### 4多字段分组
语法select s_id,f_name,count(*) from fruits group by s_id,f_name;
#### 5group by 和 order by一起使用
语法select s_id,count(*) from fruits group by s_id order by s_id;
先分组再排序
### 12.使用limit限制查询结果数量
语法select * from fruits limit 4,3;
语法select * from fruits limit 3 offset 4;
4代表是起始位置3是指三条记录
语法: select * from fruits limit 3;
第一个参数(位置偏移量)可以省略不写,表示返回前三条记录
## 二、使用集合函数查询
### 1.count()函数
1select count (*) as name from 表名;
计算表中总行数不管是不是空值
2count(字段名)
计算指定列下的总行数,忽略空值
3和group by关键字一起使用
语法select o_num,count(*) from orderitems group by o_num;
select sum(quantity) from orderitems where o_num=3005;
### 2.sum()函数(求和)
语法select o_num,sum(quantity) from orderitems group by o_num;
### 3.avg()函数(平均值)
语法select o_num,avg(item_price) from orderitems group by o_num;
### 4.max()函数(最大值)
select o_num,max(item_price) from orderitems group by o_num;
### 5.min()函数(最小值)
select o_num,min(item_price) from orderitems group by o_num;
max和min不仅可以对数值类型也可对字符类型求最大最小
## 三、连接查询
语法:
select 查询的列 from 表名 连接类型 表名2 on 连接条件
【where 筛选条件】【group by 分组字段having分组后筛选条件】【order by 排序字段】
### 1.内连接查询inner join=join
不满足 on 后连接条件的会直接过滤掉
select student.name,class.name from student join class on student.class_id=class.id where student.name like '%小%';
也可以自连接
### 2.外连接查询
分为一个主表和一个从表
外连接的查询结果为主表中的所有记录
如果从表中有和它匹配的,则显示匹配结果
如果从表中没有和它匹配的则显示null
#### 1左外连接left outer join=left join
select *from student left join class on student.class_id=class.id;//以左表为主若没有与它匹配的是空
#### 2右外连接right outer join=right join
select *from student right join class on student.class_id=class.id;//以右表为主若没有与它匹配的是空
### 3.符合条件连接查询
select student.name,class.name from student join class on student.class_id=class_id where student.name like "%小%
等价于
select student.name,class.name from student, class where student.class_id=class_id and student.name like %小%
等价于
select student.name,class.name from student join class on student.class_id-class_id and student.name like %小%
seletc * from student as s1 join student as s2 on s1.id=s2.id//自连接
## 四、子查询
## 五、合并查询结果
## 六、为表和字段取别名
## 七、使用正则表达式查询
## 八、综合案例讲解
## 上课代码
```mysql
show database;
use text2;
```
![image-20220317091555230](https://lsky.hhdxw.top/imghub/img/image-20220317091555230.png)
```mysql
create table fruits(
f_id char(10) not null primary key,
s_id int not null,
f_name char(25) not null,
f_price decimal(8,2) not null
);
desc fruits;
```
![image-20220317091623241](https://lsky.hhdxw.top/imghub/img/image-20220317091623241.png)
```mysql
insert into fruits
values('a1',101,'apple',10.2),
('b1',101,'blackberry,',5.2),
('bs1',102,'orange',11.2),
('bs2',105,'melon',8.2),
('t1',102,'banana',10.3),
('t2',102,'grape',5.3),
('o2',103,'cocount',9.2),
('c0',101,'chaerry',3.2),
('a2',103,'apricot',2.2),
('i2',104,'lemon',6.2),
('d2',104,'berry',7.6),
('m1',106,'mango',15.6),
('m2',105,'xbabay',2.6),
('t4',107,'xbababa',3.6),
('m3',105,'xxtt',11.6),
('b5',107,'xxx',3.6);
```
![image-20220317092658984](https://lsky.hhdxw.top/imghub/img/image-20220317092658984.png)
```mysql
select * from fruits;
```
![image-20220317092752192](https://lsky.hhdxw.top/imghub/img/image-20220317092752192.png)
```mysql
select f_id,s_id,f_name,f_price from fruits;
```
![image-20220317093016313](https://lsky.hhdxw.top/imghub/img/image-20220317093016313.png)
```mysql
select f_name,f_price from fruits where f_price=10.2;
select f_name,f_price from fruits where f_price>10.2;
select f_name,f_price from fruits where f_price<>10.2;
```
![image-20220317095505644](https://lsky.hhdxw.top/imghub/img/image-20220317095505644.png)
```mysql
select f_name,f_price from fruits where f_name='xxtt';
```
![image-20220317105627492](https://lsky.hhdxw.top/imghub/img/image-20220317105627492.png)
```mysql
select f_name,f_price from fruits where f_price between 5 and 10;
```
![image-20220317105740906](https://lsky.hhdxw.top/imghub/img/image-20220317105740906.png)
```mysql
select s_id,f_name,f_price from fruits where s_id in(101,102);
```
![image-20220317110130236](https://lsky.hhdxw.top/imghub/img/image-20220317110130236.png)
```mysql
select s_id,f_name,f_price from fruits where s_id not in(101,103);
```
![image-20220317110406931](https://lsky.hhdxw.top/imghub/img/image-20220317110406931.png)
```mysql
select f_name,f_price from fruits where f_price not between 5 and 10;
```
![image-20220317110825756](https://lsky.hhdxw.top/imghub/img/image-20220317110825756.png)
```mysql
select f_name,f_price from fruits where f_name like 'b%';
```
![image-20220317111434067](https://lsky.hhdxw.top/imghub/img/image-20220317111434067.png)
```mysql
select f_name,f_price from fruits where f_name like 'b%y';
```
![image-20220317111958464](https://lsky.hhdxw.top/imghub/img/image-20220317111958464.png)
```mysql
select f_name,f_price from fruits where f_name like '____y';
```
![image-20220317112329201](https://lsky.hhdxw.top/imghub/img/image-20220317112329201.png)
```mysql
select f_name,f_price from fruits where f_name is not null;
```
![image-20220317112617170](https://lsky.hhdxw.top/imghub/img/image-20220317112617170.png)
```mysql
select f_name,f_price from fruits where s_id=101 and f_price>=5;
```
![image-20220317113118208](https://lsky.hhdxw.top/imghub/img/image-20220317113118208.png)
```mysql
select s_id,f_name,f_price from fruits where s_id=101 and f_price>=5 and f_name like 'a%';
```
![image-20220317113224608](https://lsky.hhdxw.top/imghub/img/image-20220317113224608.png)
```mysql
select s_id,f_name,f_price from fruits where s_id=101 or s_id=103;
```
![image-20220317113342578](https://lsky.hhdxw.top/imghub/img/image-20220317113342578.png)
```mysql
select distinct s_id from fruits ;
```
![image-20220317114237840](https://lsky.hhdxw.top/imghub/img/image-20220317114237840.png)
```mysql
select distinct s_id from fruits order by s_id asc;
select distinct s_id from fruits order by s_id desc;
```
![image-20220317114647937](https://lsky.hhdxw.top/imghub/img/image-20220317114647937.png)
```mysql
select s_id,f_name from fruits order by f_name;
```
![image-20220317114832832](https://lsky.hhdxw.top/imghub/img/image-20220317114832832.png)
```mysql
select s_id,f_name from fruits order by s_id,f_name;
```
![image-20220322072823107](https://lsky.hhdxw.top/imghub/img/image-20220322072823107.png)
```mysql
select s_id,count(*) from fruits group by s_id;
```
![image-20220322073454144](https://lsky.hhdxw.top/imghub/img/image-20220322073454144.png)
```mysql
select s_id,count(*) as total from fruits group by s_id;
```
![image-20220322073607034](https://lsky.hhdxw.top/imghub/img/image-20220322073607034.png)
```mysql
select s_id,group_concat(f_name) from fruits group by s_id;
```
![image-20220322074058744](https://lsky.hhdxw.top/imghub/img/image-20220322074058744.png)
```mysql
select s_id,group_concat(f_name) as names from fruits group by s_id;
```
![image-20220322074217309](https://lsky.hhdxw.top/imghub/img/image-20220322074217309.png)
```mysql
select s_id,group_concat(f_name) as names from fruits group by s_id having count(f_name)>1;
```
![image-20220322074314665](https://lsky.hhdxw.top/imghub/img/image-20220322074314665.png)
```mysql
select s_id,group_concat(f_name) as names from fruits where s_id>=104 group by s_id having count(f_name)>1;
```
![image-20220322075000501](https://lsky.hhdxw.top/imghub/img/image-20220322075000501.png)
```mysql
select s_id,count(*) from fruits group by s_id with rollup;
```
![image-20220322080606749](https://lsky.hhdxw.top/imghub/img/image-20220322080606749.png)
```mysql
select s_id,f_name,count(*) from fruits group by s_id,f_name;
```
![image-20220322080806489](https://lsky.hhdxw.top/imghub/img/image-20220322080806489.png)
```mysql
select s_id,count(*) from fruits group by s_id order by s_id;
```
![image-20220322081315975](https://lsky.hhdxw.top/imghub/img/image-20220322081315975.png)
```mysql
select * from fruits limit 4,3;
```
![image-20220322081421227](https://lsky.hhdxw.top/imghub/img/image-20220322081421227.png)
```mysql
create table orderitems(
o_num int not null,
o_item int not null,
f_id char(10) not null,
quantity int not null,
item_price decimal(8,2) not null,
primary key(o_num,o_item)
);
```
![image-20220322083305461](https://lsky.hhdxw.top/imghub/img/image-20220322083305461.png)
```mysql
insert into orderitems
values(3001,1,'a1',10,5.20),
(3001,2,'b2',3,7.60),
(3001,3,'bs1',5,11.20),
(3001,4,'bs2',15,9.20),
(3002,1,'b3',2,20.00),
(3003,1,'c0',100,10.00),
(3004,1,'o2',50,2.50),
(3005,1,'c0',5,10.00),
(3005,2,'b1',10,8.99),
(3005,3,'a2',10,2.20),
(3005,4,'m1',5,14.99);
```
![image-20220322084023365](https://lsky.hhdxw.top/imghub/img/image-20220322084023365.png)
```mysql
create table customers(
c_id int not null auto_increment,
c_name char(50) not null,
c_address char(50) null,
c_city char(50) null,
c_zip char(50) null,
c_contact char(50) null,
c_email char(255) null,
primary key(c_id)
);
```
![image-20220324071225242](https://lsky.hhdxw.top/imghub/img/image-20220324071225242.png)
```
insert customers values
(1001,'Redhook','200 Street','Tianjin','300000','Liming','Lming@163.com'),
(1002,'Stars','333 Fromage lane','Dalian','116000','Zhangbo','Jerry@hotmail.com'),
(1003,'Netbhood','1 Sunny place','Qingdao','266000','Luocong',''),
(1004,'J0t0','829 Riverside drive','Haikou','570000','Yangshan','sam@hotmail.com')
;
```
![image-20220324071230024](https://lsky.hhdxw.top/imghub/img/image-20220324071230024.png)
```mysql
select o_num,count(*) from orderitems group by o_num;
```
![image-20220324072908786](https://lsky.hhdxw.top/imghub/img/image-20220324072908786.png)
```mysql
select sum(quantity) from orderitems where o_num=3005;
```
![image-20220324073307965](https://lsky.hhdxw.top/imghub/img/image-20220324073307965.png)
```mysql
select o_num,sum(quantity) from orderitems group by o_num;
```
![image-20220324073723595](https://lsky.hhdxw.top/imghub/img/image-20220324073723595.png)
```mysql
select o_num,avg(item_price) from orderitems group by o_num;
```
![image-20220324074043677](https://lsky.hhdxw.top/imghub/img/image-20220324074043677.png)
```mysql
select o_num,max(item_price) from orderitems group by o_num;
```
![image-20220324074223916](https://lsky.hhdxw.top/imghub/img/image-20220324074223916.png)
```mysql
select o_num,min(item_price) from orderitems group by o_num;
```
![image-20220324074228364](https://lsky.hhdxw.top/imghub/img/image-20220324074228364.png)
```mysql
select min(f_name) from fruits;
```
![image-20220324074524338](https://lsky.hhdxw.top/imghub/img/image-20220324074524338.png)
```mysql
fruits中查询不同供应商供应的价格最低的水果
select s_id,min(f_price) from fruits group by s_id;
```
![image-20220324074936488](https://lsky.hhdxw.top/imghub/img/image-20220324074936488.png)
```mysql
select s_id,min(f_price) from fruits group by s_id order by s_id desc;
```
![image-20220324075020970](https://lsky.hhdxw.top/imghub/img/image-20220324075020970.png)
# 底部