MySql简单查询

#(1)查询每个雇员的所有记录;
SELECT * FROM employee;
#(2)查询前5个会员的所有记录;
select * FROM employee LIMIT 0,5;
#(3)查询每个雇员的地址和电话;
SELECT Num, Addr,Tel FROM employee ;
#(4)查询num为001的雇员地址和电话;
SELECT * FROM employee where Num=001;
#(5)查询表Employee表中女雇员的地址和电话,使用AS子句将结果列中各列的标题分别指定为地址、电话;
SELECT Addr as a,Tel as t FROM employee where Sex='女';
#(6)计算每个雇员的实际收入;
SELECT Num,InCome-OutCome from salary;
#(7)找出所有性王的雇员的部门号(部门号不能重复显示);
SELECT Depno FROM employee where Name LIKE '王%' group by Depno ;
#(8)找出所有收入在2000-3000元之间的雇员编号
SELECT * FROM salary where InCome BETWEEN 2000 and 3000;

#练习2:子查询的使用(答案可以不唯一)
#(1)查找在财务部工作的雇员情况;
SELECT *FROM employee,department WHERE employee.Depno=department.Depno and DepName='财务部';
-- 内连接
SELECT e.* FROM employee e INNER JOIN 	department d on e.DepNo = d.DepNO AND d.DepName='财务部';


#(2)查找在财务部且年龄不低于研发部任一个雇员年龄的雇员的姓名;
SELECT employee.Name FROM employee,department WHERE employee.Depno=department.Depno AND DepName ='财务部' AND employee.Birth<
(SELECT min(Birth) mb FROM employee,department WHERE employee.Depno=department.Depno AND DepName ='研发部');

 
#(3)查找比所有财务部雇员收入都高的雇员的姓名;
SELECT e.Name,s.InCome FROM employee e,department d,salary s 
WHERE e.Depno=d.Depno AND e.Num = s.Num AND d.DepName !='财务部' AND s.InCome >
 (SELECT max(InCome) mi FROM employee,department,salary 
WHERE employee.Depno=department.Depno AND employee.Num=salary.Num and DepName ='研发部')






#练习3:连接查询的使用
#(1)查找每个雇员的情况及薪水情况;
SELECT employee.*,salary.* FROM employee,salary where employee.Num=salary.Num;
#(2)查找财务部收入在2200元以上的雇员姓名及其薪水详细情况;
SELECT Name,salary.*  FROM employee,salary,department 
where employee.Num=salary.Num and employee.Depno=department.Depno and 
department.DepName='财务部' AND salary.InCome > 2200;

#练习4:数据汇总
#(1)求财务部雇员的平均实际收入;
SELECT  avg(InCome-OutCome)from employee,salary,department 
where employee.Num=salary.Num and employee.Depno = department.Depno and DepName='财务部';

#(2)求财务部雇员的总人数;
SELECT count(*) 人数 from employee,department 
where employee.Depno=department.Depno AND DepName ='财务部';


#练习5:GROUP  BY 、ORDER BY 子句的使用
#(1)求各部门的雇员数(要求显示,部门号、部门名称和部门雇员数);
SELECT d.Depno,d.DepName,count(*) '姓名' FROM employee e,department d
WHERE d.Depno = e.Depno GROUP BY e.Depno;
#(2)求部门的平均薪水大于2500的部门 信息(要求显示,部门号、部门名称和平均工资)
SELECT d.DepName,d.Depno,avg(s.InCome) asi FROM employee e,department d,salary s 
WHERE e.Depno=d.Depno and e.Num=s.Num GROUP BY d.DepName , d.Depno 
HAVING avg(s.InCome)> 2500

猜你喜欢

转载自blog.csdn.net/nizhener2/article/details/81431397
今日推荐