数据库2

1.简单查询-分页查询

查询的结果中有太多的数据,一次不完成可以做成分页展示

需要用两个已知的条件:当前的页码、每页的数据量

开始查询的值 = (当前的页码-1)*每页的数据量

Select * from emp limit 开始查询的值,每页的数据量

假设每页显示5条数据,分别查询出前3页

第1页

 Select * from emp limit 0,5;

第2页

 Select * from emp limit 50,5;

第3页

 Select * from emp limit 10,5;

开始查询的值和每页的数据量必须是数值型,不能加引号。

2.复杂查询

 (1)聚合查询/分组查询

聚合查询

示例:查询出所有员工的数量

Select count(ename) from emp;

练习:使用编号列查询出所有男员工的数

Select count(eid) from emp where sex=1

练习:使用所属部门编号列查询出所有男员工的数量

查询条件不是主键 如果有NULL可能会不准确)

Select count(deptld) from emp where sex=1

函数:就是一个功能体,需要提供若干个数据,最终返回结果

 

聚合函数

count() 数量 /sum() 总和/avg()平均/max()最大/min()最小

练习:计算所有的员工工资的总和

Select sum(Salary) from emp;

练习:计算所有女员工的平均工资

Select avg(Salary) from emp() where sex=0

练习:查询出年龄最大的员工的生日

Select min(birthday) from emp;

练习:查询出10号部门的最高工资

Select max(Salary) from emp where deptld = 10;

分组查询

按照指定的列分组,不是每一个列都适合分组

分组查询只能查询分组条件和聚合函数

 

示例:查询出男女员工的数量,平均工资

Select count(eid),ava(Salary),sex from emp group by sex;

练习:查询出各个部门员工的最高工资,最低工资,工资总和

Select max(salary),min(salary),sum(salary),deptld from emp group by deptld;

加密函数md5()

例如:select md5(“123456”);

获取日期中的年份 year()

Select year(“2021-5-8”);

练习:查询出1993年出生的员工有哪些

Select * from emp where year(birthday) = 1993;

(2)子查询

示例:查询出工资最高的员工所有列

步骤1:查询出工资的最高值

Select max(Salary) from emp;

步骤2:通过最高值查询员工

Select * from emp where Salary = 20000;

综合:

Select * from emp where salary=(select max(salary) = (Select max(salary0 from emp);

练习:查询出和tom同一个部门的员工有哪些

步骤1:查询tom的部门编号-20

Select deptld from emp where ename=’tom’;

Select max(Salary) from emp;

步骤2:通过部门编号查询员工

Select * from emp where deptld = 20 and ename!=’tom’;

综合:

Select * from emp where deptld=(Select deptld from emp where deptld = 20 and ename!=’tom’);

练习:查询出和Maria同一年出生的员工有哪些

步骤1:查询Maria的出生的年份

Select year(birthday) from emp where ename=’Maria’;

步骤2:查询出这一年出生的员工,排除Maria

Select * from emp where year (birthday) = 1992 and ename != ‘Maria’;

综合:

select * from emp where year(birthday)=(select year(birthday) from emp where ename='Maria') and ename!='Maria';

(3)多表查询

查询的数据是分布在多个表中,前提是表之间是有关联的。

示例:查询出所有的员工姓名及部门名称

select ename,dname from emp,dept where deptId=did;

select emp.ename,dept.dname from emp,dept where emp.deptId=dept.did;

内连接

select ename,dname from emp inner join dept on deptId=did;

和之前的结果是一样的

左外连接

select ename,dname from emp left outer join dept on deptId=did;

显示左侧表中所有的记录,先写哪个表哪个是左

右外连接

select ename,dname from emp right outer join dept on deptId=did;

显示右侧表中所有的记录,后写哪个表哪个是右

左外连接和右外连接中的outer关键字可以省略的

全连接

full join ... to

左侧和右侧所有记录都显示

mysql 不支持

联合

 union all  联合后不合并相同的记录

 union 联合后合并相同记录

 (Select ename,dname from emp left outer join dept on deptld= did)

 unio

 (Select ename,dname from emp right outer join dept on deptld = did)

全连接解决方案:左外连接和右外连接的结界联合,合并相同的记录。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值