(1)显示所有职工的基本信息。
select * from worker;
(2)
查询所有职工所属部门的部门号,不显示重复的部门号。
select distinct 部门号 from worker;
(3)求出所有职工的人数。
select count(*) from worker;
(4)列出最高工和最低工资。
select max(工资),min(工资) from worker;
(5)列出职工的平均工资和总工资。
select avg(工资) 平均工资, sum(工资) 总工资 from worker;
(6)创建一个只有职工号、姓名和参加工作的新表,名为工作日期表。
create table worktime select 职工号,姓名,工作时间 from worker;
(7)显示所有党员的年龄。
select year(now()) -year(borth_date) from t_work where politics like '党员';
(8)列出工资在4000-8000之间的所有职工姓名
select 姓名 from worker where 工资 between 4000 and 8000;
(9)列出所有孙姓和李姓的职工姓名。
select 姓名 from worker where 姓名 like '孙%' or 姓名 like '李%';
(10)列出所有部门号为102和103日不是党员的职工号、姓名。
select 职工号,姓名,政治面貌 from worker where 部门号 like '%2' and 政治面貌 not like '党员' or 部门号 like '%3' and 政治面貌 not like '党员';
(11)将职工表t worker中的职工按出生的先后顺序排序。
select 姓名 from worker order by 出生日期 asc; #order by默认升序
(12)显示工资最高的前3名职工的职工号和姓名。
select 职工号,姓名 from worker where 1=1 order by 工资 desc limit 3;
(13)求出各部门党员的人数。
select 部门号,count(*) 党员人数 from worker where 政治面貌='党员' group by 部门号;
(14)统计各部门的工资和平均工资并保留2位小数
select department_id,round(sum(wages),2),round(avg(wages),2) from t_work where true group by department_id;
(15)列出总人数大于等于3的部门号和总人数。
select 部门号,count(*) from worker group by 部门号 having count(*) > 3;