From c4360ba9d91ce8959bb55613694d5ea0e24b2acf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9B=B9=E6=AD=A3=E6=B3=A2?= <1938448998@qq.com> Date: Thu, 9 Mar 2023 21:01:07 +0800 Subject: [PATCH 1/2] =?UTF-8?q?=E4=B8=89=E6=9C=88=E4=B9=9D=E5=8F=B7?= =?UTF-8?q?=E4=BD=9C=E4=B8=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...6\345\272\223\347\273\203\344\271\2402.md" | 81 +++++++++++++++++++ 1 file changed, 81 insertions(+) create mode 100644 "09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\347\273\203\344\271\2402.md" diff --git "a/09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\347\273\203\344\271\2402.md" "b/09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\347\273\203\344\271\2402.md" new file mode 100644 index 0000000..432446b --- /dev/null +++ "b/09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\347\273\203\344\271\2402.md" @@ -0,0 +1,81 @@ +# 作业 + +```mysql +create database lianxi2 charset utf8; +use lianxi2; +drop table riqi; +create table riqi( -- 日期表 +orderID int primary key,-- 订单编号 +orderDate datetime -- 订购日期 +); +create table shuju( -- 订单数据表 +itemID int(2), +orderID int, -- 订单编号 +foreign key(orderID) references riqi(orderID), +itemType varchar(10), -- 产品类型 +itemName varchar(10), -- 产品名称 +theNumber int(2),-- 订购数量 +theMoney int(2) -- 订购单价 +); +insert into riqi values +(1,'2008-01-12 00:00:00.000'), +(2,'2008-02-10 00:00:00.000'), +(3,'2008-02-15 00:00:00.000'), +(4,'2008-03-10 00:00:00.000'); +insert into shuju values +(1,1,'文具','笔',72,2), +(2,1,'文具','尺',10,1), +(3,1,'体育用品','篮球',1,56), +(4,2,'文具','笔',36,2), +(5,2,'文具','固体胶',20,3), +(6,2,'日常用品','透明胶',2,1), +(7,2,'体育用品','羽毛球',20,3), +(8,3,'文具','订书机',20,3), +(9,3,'文具','订书针',10,3), +(10,3,'文具','裁纸刀',5,5), +(11,4,'文具','笔',20,2), +(12,4,'文具','信纸',50,1), +(13,4,'日常用品','毛巾',4,5), +(14,4,'日常用品','透明胶',30,1), +(15,4,'体育用品','羽毛球',20,3); +-- 根据图示,完成下列题目: + +-- 1.查询所有的订单的订单的编号,订单日期,订购产品的类别和订购的产品名称,订购数量和订购单价 +select + a.orderID,a.orderDate,b.itemType,b.itemName,b.theNumber,b.theMoney + from riqi a right join shuju b on +a.orderID=b.orderID; + +-- 2.查询订购数量大于50的订单的编号,订单日期,订购产品的类别和订购的产品名称 +select b.orderID,b.orderDate,a.itemType,a.itemName from shuju a right join riqi b on a.orderID=b.orderID +where a.theNumber in (select shuju.theNumber from shuju where shuju.theNumber>50); +-- 3.查询所有的订单的订单的编号,订单日期,订购产品的类别和订购的产品名称,订购数量和订购单价以及订购总价 +select + a.orderID,a.orderDate,b.itemType,b.itemName,b.theNumber,b.theMoney,b.theNumber*b.theMoney 总价 + from riqi a right join shuju b on +a.orderID=b.orderID; +-- 4.查询单价大于等于5 或者 数量大于等于50的订单的订单的编号,订单日期,订购产品的类别和订购的产品名称,订购数量和订购单价以及订购总价 +select + a.orderID,a.orderDate,b.itemType,b.itemName,b.theNumber,b.theMoney,b.theNumber*b.theMoney 总价 + from riqi a right join shuju b on +a.orderID=b.orderID +where b.theMoney=(select shuju.theMoney from shuju where shuju.theMoney>5)or b.theNumber>=50; +-- 5.查询每个订单分别订购了几个产品,例如: +-- 编号 订购产品数 +-- 1 3 +-- 2 4 +select shuju.orderID,count(shuju.itemName) + from shuju group by shuju.orderID; +-- 6.查询每个订单里的每个类别的产品分别订购了几次和总数量,例如: +select a.orderID,a.itemType,count(*),sum(a.theNumber) +from shuju a +group by a.orderID,a.itemType +-- 订单编号 产品类别 订购次数 总数量 +-- +-- 1 文具 2 82 +-- 1 体育用品 1 1 +-- 2 文具 2 56 +-- 2 体育用品 1 2 +-- 2 日常用品 1 20 +``` + -- Gitee From 53b905e2bbc5789ca02173e3e0afe45f3b02143d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9B=B9=E6=AD=A3=E6=B3=A2?= <1938448998@qq.com> Date: Fri, 10 Mar 2023 12:11:44 +0800 Subject: [PATCH 2/2] =?UTF-8?q?=E4=B8=89=E6=9C=88=E4=B9=9D=E5=8F=B7?= =?UTF-8?q?=E4=BD=9C=E4=B8=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...23\345\244\247\344\275\234\344\270\232.md" | 106 +++++++++++++++++- 1 file changed, 105 insertions(+), 1 deletion(-) rename "09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\347\273\203\344\271\2402.md" => "09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\345\244\247\344\275\234\344\270\232.md" (37%) diff --git "a/09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\347\273\203\344\271\2402.md" "b/09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\345\244\247\344\275\234\344\270\232.md" similarity index 37% rename from "09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\347\273\203\344\271\2402.md" rename to "09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\345\244\247\344\275\234\344\270\232.md" index 432446b..f6d6ba4 100644 --- "a/09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\347\273\203\344\271\2402.md" +++ "b/09 \346\233\271\346\255\243\346\263\242/20230309 MySQL\346\225\260\346\215\256\345\272\223\345\244\247\344\275\234\344\270\232.md" @@ -1,5 +1,7 @@ # 作业 +### 练习2 + ```mysql create database lianxi2 charset utf8; use lianxi2; @@ -76,6 +78,108 @@ group by a.orderID,a.itemType -- 1 体育用品 1 1 -- 2 文具 2 56 -- 2 体育用品 1 2 --- 2 日常用品 1 20 +-- 2 日常用品 1 +``` + +## 大作业 + +```mysql +create database xiaoshuo charset utf8; +use xiaoshuo; +-- 2143 +create table author( +author_id int primary key, +author_name varchar(20) not null unique, +credits int, +vip_id varchar(20) not null, +foreign key(vip_id) references vip(vip_id) +); +create table vip( +vip_id varchar(20) primary key, +vip_name varchar(20) not null unique +); +create table story( +story_id int primary key auto_increment, +author_id int, +foreign key(author_id) references author(author_id), +type_id varchar(20), +foreign key(type_id) references type(type_id), +story_name varchar(50), +views_number int +); +create table type( +type_id varchar(20) primary key, +type_name varchar(20) not null unique +); +insert into author values + (1001,'朱逸群',600,'VIP02'), + (1002,'范建',8510,'VIP04'), + (1003,'史珍香',981,'VIP02'), + (1004,'范统',2364,'VIP02'), + (1005,'杜子腾',257,'VIP01'), + (1006,'刘产',678,'VIP02'), + (1007,'杜琦燕',438,'VIP03'); + insert into vip values + ('VIP01','青铜作家'), + ('VIP02','白银作家'), + ('VIP03','黄金作家'), + ('VIP04','钻石作家'); + insert into story values + (1,1002,'L03','母猪产后与护理师的二三事',6541), + (2,1005,'L04','拖拉机大战蜘蛛侠',563), + (3,1003,'L01','这只小龙虾不正经',8754), + (4,1006,'L04','一个爹爹三个娃',36354), + (5,1006,'L01','皇上滚开本宫只劫财',3674), + (6,1005,'L05','给长城贴瓷砖的小太监',6541), + (7,1003,'L03','不科学御兽',1257), + (8,1005,'L01','镜面管理局',3216), + (9,1004,'L02','关于我成为灭魂师之后',1147), + (10,1004,'L05','公子别秀',2078); +insert into type values + ('L01','玄幻'), + ('L02','奇幻'), + ('L03','武侠'), + ('L04','仙侠'), + ('L05','都市'); +-- 1. 根据前面提供的表结构和表数据,创建数据库并分别创建这张四张表;并插入相关数据。(提醒:外键 +-- 请注意建表顺序和插入数据的顺序) (30分) +-- 2. 将story 表中的story_name字段类型改成varchar(40) 。(2分) +alter table story modify story_name varchar(40); +-- 3. 在author表中增加一个性别字段 字段名:author_sex,类型: char(10),要求默认值为'男'。 (3分) +alter table author add author_sex char(10) DEFAULT '男'; +-- 4. 将作家编号为1005、1007的作家性别改为'女' 。(2分) +update author set author_sex='女' where author_id='1005' or author_id='1007'; +-- 5. 作家杜子腾,写了一篇名为《拜登夸我很帅》的都市小说,有854个浏览量,请将这条信息插入到story +insert into story values(11,1005,'L05','拜登夸我很帅',854); +-- 表。(3分) +-- 6. 《拖拉机大战蜘蛛侠》这篇小说,浏览量涨了100,请更新story表中的相关数据。(2分) +update story set views_number=views_number+100 where story_name='拖拉机大战蜘蛛侠'; +-- 7. 请删除story表的中《皇上滚开本宫只劫财》这篇小说相关数据。(2分) +delete from story where story_name='皇上滚开本宫只劫财'; +-- 8. 查询 浏览量大于 8000的小说的作者编号和小说作品名称。(2分) +select * from story where views_number>8000; +-- 9. 查询积分大于1000 并且会员等级高于vip03的作家所有信息。(3分) +select * from author where credits>1000 and vip_id>'vip03'; +-- 10. 查询姓名以杜字开头的作家的姓名,积分和等级编号。(3分) +select author_name,credits,vip_id from author where author_name like '杜%'; +-- 11. 查询积分在100、1000之间的作家信息,以积分降序排列。 (3分) +select * from author where credits between 100 and 1000 order by credits desc; +-- 12. 查询出小说的总浏览量,最高浏览量,最小浏览量,平均浏览量,给字段用上中文别名。(3分) +select sum(views_number) 总浏览量,max(views_number) 最高浏览量,min(views_number) 最小浏览量,avg(views_number) 平均浏览量 from story; +-- 13. 查询各种等级的作家的平均积分和作家数量,并对查询结果使用中文别名。(3分) +select vip_id 作家等级,avg(credits) 平均积分,count(author_name) 作家数量 from author group by vip_id; +-- 14. 查询小说数量大于等于2的分类编号和小说数量。(4分) +select type_id,count(type_id) 小说数量 from story where type_id>='L02' group by type_id; +-- 15. 查询所有小说中浏览量最少的书的作品编号、作品名称和类型编号、浏览量。(4分) +select story_id,story_name,type_id,views_number from story where views_number = (select min(views_number) from story); +-- 16. 查询积分比刘产高的作者所有信息。(5分) +select * from author where credits > (select credits from author where author_name='刘产'); +-- 17. 查询出哪些白银作家是没有写小说的,显示这些作家的姓名、等级名称。(8分) +select author_name,vip_name from vip v right join author a on v.vip_id=a.vip_id left join story s on a.author_id=s.author_id where story_id is null and vip_name='白银作家'; +-- 18. 找出写过作品浏览量大于5000的作家的所有作品中浏览量不到1000的作品信息(8分) +select * from story where author_id in (select author_id from story where views_number>5000) and views_number<1000; +-- 19. 查询所有小说的小说编号、小说名称、浏览量、分类名称、作者姓名、作者积分、作者等级名称,结果 +-- 字段要用中文别名,并按浏览量降序排列,如果浏览量一样的,再按积分降序排列。(10分) + ``` -- Gitee