From 81cfd62379c0cd8834b9ba2bb8ec892435d084c7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E4=BD=99=E5=80=A9?= <2931430074@qq.com> Date: Sun, 12 Mar 2023 16:51:12 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BD=99=E5=80=A9=E7=9A=84=E4=BD=9C=E4=B8=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...8 \345\244\247\344\275\234\344\270\232.md" | 173 ++++++++++++++++++ .../20230309 \347\273\203\344\271\240.md" | 145 +++++++++++++++ 2 files changed, 318 insertions(+) create mode 100644 "24 \344\275\231\345\200\251/20230308 \345\244\247\344\275\234\344\270\232.md" create mode 100644 "24 \344\275\231\345\200\251/20230309 \347\273\203\344\271\240.md" diff --git "a/24 \344\275\231\345\200\251/20230308 \345\244\247\344\275\234\344\270\232.md" "b/24 \344\275\231\345\200\251/20230308 \345\244\247\344\275\234\344\270\232.md" new file mode 100644 index 0000000..781d43c --- /dev/null +++ "b/24 \344\275\231\345\200\251/20230308 \345\244\247\344\275\234\344\270\232.md" @@ -0,0 +1,173 @@ +# 一,练习 + + + +```sql +CREATE DATABASE xuexi CHARSET utf8; +USE xuexi; + +CREATE TABLE riqi( +orderid int, +orderdate datetime +) + +CREATE TABLE wuping( +itemid int, +orderid int, +itemtype VARCHAR(5), +itemname VARCHAR(5), +thenumber int, +themoney int +); + +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 wuping 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 * FROM wuping LEFT JOIN riqi on wuping.orderid=riqi.orderid; +-- + +-- 2.查询订购数量大于50的订单的编号,订单日期,订购产品的类别和订购的产品名称 + +SELECT * FROM wuping LEFT JOIN riqi on wuping.orderid=riqi.orderid WHERE thenumber >50; +-- + +-- 3.查询所有的订单的订单的编号,订单日期,订购产品的类别和订购的产品名称,订购数量和订购单价以及订购总价 +SELECT * ,thenumber*themoney 总价 FROM wuping LEFT JOIN riqi on wuping.orderid=riqi.orderid ; + +-- +-- 4.查询单价大于等于5 或者 数量大于等于50的订单的订单的编号,订单日期,订购产品的类别和订购的产品名称,订购数量和订购单价以及订购总价 +SELECT * FROM wuping LEFT JOIN riqi on wuping.orderid=riqi.orderid WHERE thenumber >=50 or themoney>=5; + +-- +-- 5.查询每个订单分别订购了几个产品,例如: +-- 编号 订购产品数 +-- 1 3 +-- 2 4 +SELECT orderid,count(thenumber) FROM wuping GROUP BY orderid; + +-- + +-- 6.查询每个订单里的每个类别的产品分别订购了几次和总数量,例如: +-- + +-- 订单编号 产品类别 订购次数 总数量 +-- + +-- 1 文具 2 82 +-- 1 体育用品 1 1 +-- 2 文具 2 56 +-- 2 体育用品 1 2 +-- 2 日常用品 1 20 + +SELECT orderid,itemtype,count(itemtype),sum(thenumber) FROM wuping GROUP BY orderid,itemtype; +``` + + + +# 二,大作业 + +```sql +-- +-- -- **数据库名**:xiaoshuo +CREATE DATABASE xiaoshuo CHARSET utf8; + +use xiaoshuo; +-- + +-- -- 该数据库里有四张表:作家信息表 ( author )、作家等级信息表 ( vip )、小说作品信息表 ( story )、小说作品类型表 ( type ) + + +CREATE TABLE vip( + vip_id varchar(20) PRIMARY KEY COMMENT '等级编号', + vip_name varchar(20) unique key COMMENT'等级名称' +); +CREATE TABLE type( +type_id varchar(20) PRIMARY KEY COMMENT '类型编号', +type_name varchar(20) not null unique key COMMENT'类型名称' + ); + CREATE TABLE author( + author_id int PRIMARY KEY COMMENT '作家编号', + author_name varchar(20) not null unique key COMMENT'作家姓名', + credits int COMMENT'积分', + vip_id varchar(20)not null COMMENT'等级编号', + foreign key (vip_id) references vip(vip_id) + ); +CREATE TABLE story( +story_id int PRIMARY KEY COMMENT'作品编号', +author_id int COMMENT'作家编号', +type_id varchar(20) COMMENT'类型编号', +story_name varchar(50) COMMENT'作品名称', +views_number int COMMENT'浏览量', +foreign key (author_id) references author(author_id), +foreign key (type_id) references type(type_id) + ); + + +INSERT into vip VALUES('VIP01','青铜作家'),('VIP02','白银作家'),('VIP03','黄金作家'),('VIP04','钻石作家'); + +INSERT INTO type VALUES('L01','玄幻'),('L02','奇幻'),('L03','武侠'),('L04','仙侠'),('L05','都市'); + +INSERT into author VALUES(1001,'朱逸群',600,'VIP01'),(1002,' 范建 ',8510,'VIP04'),(1003,'史珍香',981,'VIP02'),(1004,' 范统 ',2364,'VIP02'),(1005,'杜子腾',257,'VIP01'),(1006,' 刘产 ',678,'VIP02'),(1007,'杜琦燕',438,'VIP03'); + +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','镜面管理局',3214),(9,1004,'L02','关于我成为灭魂师之后',1147),(10,1004,'L05','公子别秀',2078); + + +alter table story change story_name story_name varchar(40); +desc story + +-- 3. 在author表中增加一个性别字段 字段名:author_sex,类型: char(10),要求默认值为'男'。 (3分) +alter table author add author_sex char(10) default '男'; +desc author +-- 4. 将作家编号为1005、1007的作家性别改为'女' 。(2分) +update author set author_sex = '女'where author_id=1005 or author_id=1007; + +-- 5. 作家杜子腾,写了一篇名为《拜登夸我很帅》的都市小说,有854个浏览量,请将这条信息插入到story表。(3分) +INSERT into story VALUES(11,1005,'L01','拜登夸我很帅',854); +-- 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 author_id,story_name FROM story WHERE views_number>8000; +-- 9. 查询积分大于1000 并且会员等级高于vip03的作家所有信息。(3分) + +SELECT * FROM author WHERE credits >1000 AND vip_id >'VIP03'; +-- 10. 查询姓名以杜字开头的作家的姓名,积分和等级编号。(3分) +SELECT * 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 avg(credits) 平均积分,count(*) 作家数量,vip_id 等级 FROM author GROUP BY vip_id; +-- 14. 查询小说数量大于等于2的分类编号和小说数量。(4分) + +SELECT type_id,count(story_name) FROM story GROUP BY type_id HAVING count(story_name)>=2; + +-- 15. 查询所有小说中浏览量最少的书的作品编号、作品名称和类型编号、浏览量。(4分) +SELECT * 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=' 刘产 '); +SELECT credits FROM author WHERE author_name=' 刘产 '; + +-- 17. 查询出哪些白银作家是没有写小说的,显示这些作家的姓名、等级名称。(8分) +SELECT author.author_name,author.vip_id FROM author LEFT JOIN story on author.author_id=story.author_id LEFT JOIN vip ON author.vip_id=vip.vip_id WHERE story.story_name is null; +-- 18. 找出写过作品浏览量大于5000的作家的所有作品中浏览量不到1000的作品信息(8分) +SELECT * FROM story WHERE views_number > 5000 or views_number < 1000; +-- 19. 查询所有小说的小说编号story.story_id、小说名称story.story_name、浏览量sotry.views_number、分类名称story.type_id、作者姓名author.author_name、作者积分author.credits、作者等级名称author.vip_id,结果字段要用中文别名,并按浏览量降序排列,如果浏览量一样的,再按积分降序排列。(10分) +SELECT story.story_id 小说编号,story.story_name 小说名称,story.views_number 浏览量,story.type_id 分类名称,author.author_name 作者姓名,author.credits 作者积分,author.vip_id 作者等级名称 FROM author INNER JOIN story on author.author_id=story.author_id ORDER BY views_number desc; + + + + +``` + diff --git "a/24 \344\275\231\345\200\251/20230309 \347\273\203\344\271\240.md" "b/24 \344\275\231\345\200\251/20230309 \347\273\203\344\271\240.md" new file mode 100644 index 0000000..b8a4f7c --- /dev/null +++ "b/24 \344\275\231\345\200\251/20230309 \347\273\203\344\271\240.md" @@ -0,0 +1,145 @@ +```sql + CREATE DATABASE ku charset utf8; + use ku; + +CREATE TABLE stuinfo( +stuNO char(5), +stuName VARCHAR(4), +stuSex char(1), +stuAge int(3), +stuaderss char(10), +stuseat int +); +CREATE TABLE stuexam( +examno int, +stuno char(5), +wittenexam int, +labexam int +); + + +insert into stuinfo VALUES ('s2501','张秋利','男',20,'美国硅谷',1),('s2502','李斯文','女',18,'湖北武汉',2),('s2503','马文才','男',18,'湖南长沙',3),('s2504','欧阳俊雄','女',21,'湖北武汉',4),('s2505','梅超风','男',20,'湖北武汉',5),('s2506','陈旋风','男',19,'美国硅谷',6) + +insert into stuexam VALUES (1,'s2501',50,70),(2,'s2502',60,65),(3,'s2503',86,70),(4,'s2504',40,80),(5,'s2505',70,85),(6,'s2506',85,90); + +delete from stumarks; +-- 1.查询学生信息表(stuinfo)中所有列信息,给每列取上中文名称 + +SELECT stuNO 学号,stuName 姓名,stuSex 性别,stuAge 年龄,stuaderss 地址,stuseat 座位号 FROM stuinfo; +-- + +-- 2.查询学生信息表(stuinfo)中的姓名,年龄和地址三列的信息 + +SELECT stuName,stuAge,stuaderss FROM stuinfo; +-- + +-- 3.查询学生分数表(stuexam)中的学号,笔试和机试三列的信息,并为这三列取中文名字 + +SELECT stuno 学号,wittenexam 笔试,labexam 机试 FROM stuexam; +-- + +-- 5.查询学生分数表(stuexam)中的学生的学号,笔试,机试以及总分这四列的信息 + +SELECT stuno 学号,wittenexam 笔试,labexam 机试,(wittenexam+labexam) 总分 FROM stuexam; +-- + +-- 6.查询学生信息表(stuInfo)中学生来自哪几个地方 + +SELECT stuName,stuaderss FROM stuinfo; +-- + +-- 7.查询学生信息表(stuInfo)中学生有哪几种年龄,并为该列取对应的中文列名 + +SELECT DISTINCT stuage 年龄 from stuinfo; +-- + +-- 8.查询学生信息表(stuInfo)中前3行记录 + +SELECT * FROM stuinfo WHERE stuseat in (1,2,3); +-- + +-- 9.查询学生信息表(stuInfo)中前4个学生的姓名和座位号 + +SELECT stuName,stuseat FROM stuinfo WHERE stuseat in (1,2,3,4); +-- + +-- 11.将地址是湖北武汉,年龄是20的学生的所有信息查询出来 + +SELECT * FROM stuinfo WHERE stuaderss='湖北武汉' and stuAge=20; +-- + +-- 12.将机试成绩在60-80之间的信息查询出来,并按照机试成绩降序排列 + +SELECT * FROM stuexam WHERE labexam BETWEEN 60 and 80 ORDER BY labexam DESC; +-- + +-- 13.查询来自湖北武汉或者湖南长沙的学生的所有信息 + +SELECT * FROM stuinfo WHERE stuaderss='湖北武汉' or stuaderss='湖南长沙'; +-- + +-- 14.查询出笔试成绩不在70-90之间的信息,并按照笔试成绩升序排列 + +SELECT * FROM stuexam WHERE wittenexam NOT BETWEEN 70 and 90 ORDER BY wittenexam ; +-- 15.查询年龄没有写的学生所有信息 + +SELECT * FROM stuinfo WHERE stuAge is NULL; + +-- 16.查询年龄写了的学生所有信息 + +SELECT * FROM stuinfo WHERE stuAge is not NULL; +-- 17.查询姓张的学生信息 + +SELECT * FROM stuinfo WHERE stuName like '张%'; +-- + +-- 18.查询学生地址中有‘湖’字的信息 + +SELECT * FROM stuinfo WHERE stuaderss like '%湖%'; +-- + +-- 19.查询姓张但名为一个字的学生信息 + +SELECT * FROM stuinfo WHERE stuName like '张_' +-- + +-- 20.查询姓名中第三个字为‘俊’的学生的信息,‘俊’后面有多少个字不限制 + +SELECT * FROM stuinfo WHERE stuName like '__俊%' +-- + +-- 21.按学生的年龄降序显示所有学生信息 + +SELECT * FROM stuinfo ORDER BY stuAge desc; +-- + +-- 22.按学生的年龄降序和座位号升序来显示所有学生的信息 + +SELECT * FROM stuinfo ORDER BY stuAge desc,stuseat +-- + +-- 23显示笔试第一名的学生的考试号,学号,笔试成绩和机试成绩 + +SELECT examno,stuno,wittenexam,labexam FROM stuexam WHERE wittenexam=(SELECT MAX(wittenexam) FROM stuexam ); +-- + +-- 24.显示机试倒数第一名的学生的考试号,学号,笔试成绩和机试成绩 + +SELECT examno,stuno,wittenexam,labexam FROM stuexam WHERE labexam=(SELECT min(labexam) FROM stuexam); +-- + +-- 25.查询每个地方的学生的平均年龄 + +SELECT stuaderss,avg(stuage) from stuinfo GROUP BY stuaderss; +-- + +-- 26.查询男女生的分别的年龄总和 + +SELECT stusex,sum(stuAge) from stuinfo GROUP BY stusex; +-- + +-- 27.查询每个地方的男女生的平均年龄和年龄的总和 + +SELECT DISTINCT avg(stuAge),sum(stuAge) from stuinfo GROUP BY stusex,stuaderss; +``` + -- Gitee