mysql-练习(基础练习、分组,查询)

create table emp(
  id int comment '编号',
  workno varchar(10) comment '工号',
  name varchar(10) comment '姓名',
  gender char(1) comment '性别',
  age tinyint unsigned comment '年龄',
  idcard char(18) comment '身份证号',
  workaddress varchar(50) comment '工作地址',
  entrydate date comment '入职时间'
) comment '员工表';

insert into emp(id,workno,name,gender,age,idcard,workaddress,entrydate)
values (1,'1','程心','女',20,'123456789012345678','北京','2009-01-01'),
       (2,'2','章北海','男',27,'123456789012345679','北京','2000-09-01'),
       (3,'3','罗辑','男',27,'123456789012345678','北京','2002-09-01'),
       (4,'4','罗德','男',39,'12345678901234567X','上海','1997-03-24');

-- 1. 查询所有员工的工作地址
select workaddress from emp;
-- 2. 查询公司员工的上班地址(不要重复)
select distinct workaddress from emp;

-- 1. 查询年龄等于20的员工
select * from emp where age=20;
-- 2. 查询年龄小于20的员工信息
select * from emp where age<20;
-- 3. 查询年龄小于等于20的员工信息
select * from emp where age <= 20;
-- 4. 查询没有身份证号的员工
select * from emp where idcard is null or idcard = '';
-- 5. 查询有身份证号的员工
select * from emp where idcard is not null and idcard != '';
-- 6. 查询年龄不等于20的员工
select * from emp where age != 20;
-- 7. 查询年龄在15岁(包含)到30岁(包含)之间的员工信息
select * from emp where age >= 15 and age <= 30;
-- 8. 查询性别为女且年龄小于25岁的员工信息
select * from emp where gender = '女' and age < 25;
-- 9. 查询年龄等于等于25或30或35的信息
select * from emp where age in (25,30,35);
-- 10. 查询姓名为两个字的信息
select * from emp where length(name)=2;
-- 11. 查询身份证最后为X的员工信息
select * from emp where idcard like '%X';
-- 12. 查询北京市的员工人数
select count(*) from emp where workaddress like '北京%'; 

-- 1. 根据性别分组,统计男性和女性数量
select gender,count(*) as count
from emp
group by gender;
-- 2. 根据性别分组,统计男性和女性的平均年龄
select gender,avg(age) as avg_age
from emp
group by gender;
-- 3. 年龄小于45,并根据工作地址分组,获取员工数量大于等于3的工作地址
select workaddress,count(*) as count
from emp
where age < 45
group by workaddress
having count >= 3;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王新宇-OO

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值