100道MySQL练习题,帮你熟悉sql语法【后50道】

1、查询id、货品名称、分类编号、零售价,并且零售价(salePrice)按降序排列:

 select id,productName,dir_id,salePrice from product order by salePrice desc;

[图片上传失败...(image-1549f3-1649149727008)]

2、查询id、货品名称、分类编号、零售价,并且零售价按升序排列:

 select id,productName,dir_id,salePrice from product order by salePrice asc;

[图片上传失败...(image-176a31-1649149727008)]

3、查询id、货品名称、分类编号、零售价,先按分类编号升序排列,再零售价按降序排列:

 select id,productName,dir_id,salePrice from product order by dir_Id asc,salePrice desc;

[图片上传失败...(image-4066d8-1649149727008)]

4、查询M系列的id、货品名称、并按照批发价(salePrice*cutoff)升序排列,批发价使用别名:

select
    id,
    productName,
    salePrice * cutoff as trade_price
from
    product
where
    productName like '%M%'
order by
    trade_price asc;

[图片上传失败...(image-605554-1649149727008)]

5、查询id、货品名称、分类编号,按分类编号为2的商品按照批发价(salePrice*cutoff)升序排列:

select
    id,
    productName,
    dir_id,
    salePrice * cutoff trade_price
from
    product
where
    dir_id = 2
order by
    trade_price asc;

[图片上传失败...(image-e87ea9-1649149727008)]

6、分页查询所有商品信息,每页五条,第一页:

  select * from product limit 0,5;

[图片上传失败...(image-d5fecb-1649149727008)]

7、分页查询所有商品信息,每页五条,第三页:

select * from product limit 10,5;

[图片上传失败...(image-6ee356-1649149727008)]

8、分页查询所有商品信息,每页五条,第五页:

 select * from product limit 20,5;

[图片上传失败...(image-f0417c-1649149727008)]

9、查询所有商品的平均零售价(salePrice):

  select avg(salePrice) from product;

[图片上传失败...(image-75370b-1649149727008)]

10、查询商品总的条数:

select count(id) from product;

[图片上传失败...(image-260fbf-1649149727008)]

11、查询分类编号为2的商品总数:

 select COUNT(id) from product where dir_id=2;

[图片上传失败...(image-b2690f-1649149727008)]

12、查询商品的最低零售价(salePrice),最高零售价(salePrice),以及所有商品零售价的总和:

 select min(salePrice),max(salePrice),sum(salePrice) from product;

[图片上传失败...(image-60b0a5-1649149727008)]

13、按照零售价(salePrice)升序排列,并设置每页显示5条数据:

select * from product order by salePrice limit 0,5;

[图片上传失败...(image-1b78d-1649149727008)]

14、查询id、货品名称(productName),以及货品所属分类名称(dirName):

建表语句:

CREATE TABLE productdir(
  id bigint(20) PRIMARY KEY AUTO_INCREMENT,
  dirName varchar(20),
  parent_id bigint(20)
);
INSERT INTO productdir VALUES (1, '鼠标', NULL);
INSERT INTO productdir VALUES (2, '无线鼠标', 1);
INSERT INTO productdir VALUES (3, '有线鼠标', 1);
INSERT INTO productdir VALUES (4, '游戏鼠标', 1);

答案:

select
    product.id,
    product.productName,
    productdir.dirName
from
    product,
    productdir
where
    product.dir_id = productdir.id;

[图片上传失败...(image-8a944b-1649149727008)]

15、查询商品零售价(salePrice)大于200的无线鼠标的所有信息:

select
    *
from
    product,
    productdir
where
    product.dir_id = productdir.id
    and salePrice > 200
    and dirName = '无线鼠标';

[图片上传失败...(image-759367-1649149727008)]

16、查询商品名称(productName)、每个货品对应的分类名称(dirName)以及对应的库存量(storeNum):

建表语句:

CREATE TABLE productstock(
   id bigint(20) PRIMARY KEY AUTO_INCREMENT,
   product_id bigint(20),
   storeNum bigint(20),
   lastIncomeDate datetime,
   lastOutcomeDate datetime,
   warningNum bigint(20)
);

INSERT INTO productstock VALUES (1, 1, 182, '2020-04-08 09:22:21', '2020-04-09 09:22:26', 20);
INSERT INTO productstock VALUES (2, 2, 27, '2020-04-10 09:22:46', '2020-04-11 09:22:40', 20);
INSERT INTO productstock VALUES (3, 3, 89, '2020-03-03 09:22:57', '2020-03-12 09:23:05', 20);
INSERT INTO productstock VALUES (4, 5, 19, '2020-04-09 09:23:30', '2020-04-17 09:23:25', 20);
INSERT INTO productstock VALUES (5, 6, 3, '2020-04-07 09:25:05', '2020-04-09 09:25:11', 5);
INSERT INTO productstock VALUES (6, 7, 2, '2020-04-08 09:25:28', '2020-04-10 09:25:24', 3);
INSERT INTO productstock VALUES (7, 8, 120, '2020-04-09 09:25:44', '2020-04-10 09:25:47', 20);
INSERT INTO productstock VALUES (8, 9, 58, '2020-04-07 09:26:03', '2020-04-09 09:25:59', 20);
INSERT INTO productstock VALUES (9, 11, 28, '2020-04-01 09:26:21', '2020-04-15 09:26:26', 20);
INSERT INTO productstock VALUES (10, 12, 8, '2020-04-02 09:26:38', '2020-04-14 09:26:35', 5);
INSERT INTO productstock VALUES (11, 13, 3, '2020-04-03 09:26:53', '2020-04-13 09:26:57', 5);
INSERT INTO productstock VALUES (12, 14, 6, '2020-04-04 09:27:11', '2020-04-12 09:27:07', 5);
INSERT INTO productstock VALUES (13, 15, 2, '2020-04-05 09:27:26', '2020-04-11 09:27:39', 5);
INSERT INTO productstock VALUES (14, 16, 3, '2020-04-06 09:28:04', '2020-04-10 09:28:00', 3);
INSERT INTO productstock VALUES (15, 17, 49, '2020-04-07 09:28:20', '2020-04-09 09:28:25', 20);
INSERT INTO productstock VALUES (16, 18, 14, '2020-04-07 09:28:49', '2020-04-14 09:28:37', 10);
INSERT INTO productstock VALUES (17, 20, 7, '2020-04-06 09:29:09', '2020-04-13 09:29:13', 5);

答案:

select
    product.productName,
    productdir.dirName,
    productstock.storeNum
from
    product,
    productdir,
    productstock
where
    product.dir_id = productdir.id
    and product.id = productstock.product_id;

[图片上传失败...(image-59fde5-1649149727008)]

17、如果库存商品销售完成,按照利润(salePrice-costPrice)从高到底查询货品名称(productName),零售价(salePrice),货品分类名称(dirName):

 select
    product.productName,
    product.salePrice,
    product.costPrice,
    productstock.storeNum,
    productdir.dirName,
(salePrice - costPrice) * storeNum profit 
from
    product,
    productdir,
    productstock
where
    product.dir_id = productdir.id
    and product.id = productstock.product_id
order by
    profit desc;

[图片上传失败...(image-67139e-1649149727008)]

注:因为下面的题目没给创建emp表的代码,而且操作也简单,所以底下的sql操作并没有得到验证,如发现问题请不吝指正🥰

18、查询所有的员工信息:

 select * from emp;

19、查询每个员工的编号(dmpno)、姓名(ename)、职位(job):

 select dmpno,ename,job from emp;

20、查询所有部门信息:

建表语句:

CREATE TABLE dept  (
  DEPTNO bigint(20) PRIMARY KEY ,
  DNAME varchar(30),
  LOC varchar(30)   
)

INSERT INTO dept VALUES (10, 'ACCOUNTING', 'NEWTORK');
INSERT INTO dept VALUES (20, 'RESEARCH', 'DALLAS');
INSERT INTO dept VALUES (30, 'SALES', 'CHICAGO');
INSERT INTO dept VALUES (40, 'OPERATIONS', 'BOSTON');

答案:

 select * from dept;

[图片上传失败...(image-4d57c6-1649149727008)]

21、查询员工的部门编号(deptno)并去除重复:

 select distinct deptno from emp;

22、查询所有员工的姓名以及对应的年薪:

select ename,sal*12 from emp;

23、查询所有员工的姓名以及对应的年薪(使用别名):

 select ename,sal*12 as annual_salary from emp;

24、查询每月都有500元的餐补和200元的交通补贴并且年底多发一个月的工资的年薪:

 select ename,(sal+500+200)*12+sal from emp;

25、查询基本工资(sal)高于1500的员工所有信息:

 select * from emp where sal>1500;

26、查询名为SCOTT员工的岗位(job)是什么:

 select job from emp where ename='SCOTT';

27、查询年薪小于3万的员工的所有信息:

 select * from emp where sal*12 < 30000;

28、查询所有不是销售人员(salesman)的所有信息:

 select * from emp where job!='salesman';

29、查询工资在2000-3000之间的所有员工信息(使用区间查询):

 select * from emp where sal between 2000 and 3000;

30、查询工资不在2000-3000之间的所有员工信息(使用区间查询):

   select * from emp where sal not between 2000 and 3000;

31、查询工资为800、1600、3000的所有员工信息(使用IN):

 select * from emp where sal in(800,1600,3000);

32、查询工资不为800、1600、3000的所有员工信息(使用IN):

 select * from emp where sal not in(800,1600,3000);

33、查询所有员工名字(ename)以A字母开头的员工信息:

 select * from emp where ename like 'A%';

34、查询所有员工名字(ename)第二个字母是M的员工信息:

select * from emp where ename like '_M%';

35、查询所有员工名字(ename)中有A字母的员工信息:

 select * from emp where ename like '%A%';

36、查询员工名字(ename)中有E或者A的员工信息:

  select * from emp where ename like '%E%' or '%A%';

37、查询工资在1500-3000之间的所有员工信息:

 select * from emp where sal >=1500 and sal <=3000;

38、查询所有员工信息,按工资(sal)升序排列:

select * from emp order by sal asc;

39、查询所有员工信息,按年薪降序排列:

select * from emp order by sal*12 desc;

40、查询所有员工信息,按照部门(deptno)和年薪降序排列:

select * from emp order by deptno desc ,sal*12 desc;

41、把所有员工分页,每页5条信息,第一页SQL:

 select * from emp limit 0,5;

42、把所有员工分页,每页5条信息,第三页SQL:

 select * from emp limit 10,5;

43、查询所有员工每个月支付工资的平均工资和总工资:

 select avg(sal),sum(sal) from emp;

44、查询月薪在2000以上的员工人数:

 select count(dmpno) from emp where sal>2000;

45、查询员工最高工资:

 select max(sal) from emp;

46、查询员工最低工资:

 select min(sal) from emp;

47、查询员工最高工资和最低工资的差额:

 select max(sal)-min(sal) from emp;

48、统计30部门的总人数:

select count(dmpno) from emp where deptno = 30;

49、查询奖金(comm)为空的所有员工信息:

 select * from emp where comm is null;

50、统计没有奖金的员工人数:

  select count(dmpno) from emp where comm is null;
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容