From 1298a98b807ef5c8d46a11bfaf5aaa1a0caa3487 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=B5=96=E5=BF=83=E5=A6=8D?= <2392642810@qq.com> Date: Thu, 9 Mar 2023 22:58:05 +0800 Subject: [PATCH 1/4] =?UTF-8?q?3.09=20=E4=BD=9C=E4=B8=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../3.09 \344\275\234\344\270\232.md" | 268 ++++++++++++++++++ 1 file changed, 268 insertions(+) create mode 100644 "03\350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" diff --git "a/03\350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" "b/03\350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" new file mode 100644 index 0000000..a9529b3 --- /dev/null +++ "b/03\350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" @@ -0,0 +1,268 @@ +## 练习 + +```mysql +create database zuoyue; + +use zuoyue; + +create table ordertime( + orderid int primary key, + orderdate datetime +); + +insert into ordertime 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'); + +create table item ( + itemid int(11) primary key, + orderid int, + itemtype varchar(10), + itemname varchar(10), + thenumber int(11), + themoney int(11) +); + +ALTER TABLE item CONVERT TO CHARACTER SET utf8; + +insert into item 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.查询所有的订单的订单的编号,订单日期,订购产品的类别和订购的产品名称,订购数量和订购单价 + +```mysql +select a.*,itemtype,itemname,thenumber,themoney from ordertime a right join item b on a.orderid=b.orderid; +``` + +2.查询订购数量大于50的订单的编号,订单日期,订购产品的类别和订购的产品名称 + +```mysql +select a.*,itemtype,itemname from ordertime a right join item b on a.orderid=b.orderid where thenumber>50; +``` + +3.查询所有的订单的订单的编号,订单日期,订购产品的类别和订购的产品名称,订购数量和订购单价以及订购总价 + +```mysql +select a.*,itemtype,itemname,thenumber,themoney,(thenumber*themoney) 订购总价 from ordertime a right join item b on a.orderid=b.orderid ; +``` + +4.查询单价大于等于5 或者 数量大于等于50的订单的订单的编号,订单日期,订购产品的类别和订购的产品名称,订购数量和订购单价以及订购总价 + +```mysql +select a.*,itemtype,itemname,thenumber,themoney,(thenumber*themoney) 订购总价 from ordertime a right join item b on a.orderid=b.orderid where themoney>=5 or thenumber>=50; +``` + +5.查询每个订单分别订购了几个产品 + +```mysql +select itemid 编号,thenumber 订购产品数 from item; +``` + +6.查询每个订单里的每个类别的产品分别订购了几次和总数量 + +```mysql +select orderid 订单编号,itemtype 产品类别,count(thenumber) 订购次数,sum(thenumber) 总数量 from item group by orderid,itemtype; +``` + + + +## 大作业 + +```mysql +create database xiaoshuo charset utf8; + +use xiaoshuo; +``` + +1. 根据前面提供的表结构和表数据,创建数据库并分别创建这张四张表;并插入相关数据。(提醒:外键请注意建表顺序和插入数据的顺序) (30分) + + ```mysql + create table author( + author_id int primary key comment '作家编号', + author_name varchar(20) unique not null comment '作家姓名', + credits int comment '积分', + vip_id varchar(20) not null comment '等级编号', + foreign key(vip_id) references vip(vip_id) + ); + + 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'); + + create table vip( + vip_id varchar(20) primary key comment '等级编号', + vip_name varchar(20) unique not null comment '等级名称' + ); + + insert into vip values + ('VIP01','青铜作家'), + ('VIP02','白银作家'), + ('VIP03','黄金作家'), + ('VIP04','钻石作家'); + + create table story( + story_id int primary key auto_increment 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 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); + + create table type( + type_id varchar(20) primary key comment '类型编号', + type_name varchar(20) unique not null comment '类型名称' + ); + + insert into type values + ('L01','玄幻'), + ('L02','奇幻'), + ('L03','武侠'), + ('L04','仙侠'), + ('L05','都市'); + ``` + +2. 将story 表中的story_name字段类型改成varchar(40) 。(2分) + + ```mysql + alter table story modify story_name varchar(40); + ``` + +3. 在author表中增加一个性别字段 字段名:author_sex,类型: char(10),要求默认值为'男'。 (3分) + + ```mysql + alter table author add author_sex char(10) default '男'; + ``` + +4. 将作家编号为1005、1007的作家性别改为'女' 。(2分) + + ```mysql + update author set author_sex='女' where author_id=1005 or author_id=1007; + ``` + +5. 作家杜子腾,写了一篇名为《拜登夸我很帅》的都市小说,有854个浏览量,请将这条信息插入到story表。(3分) + + ```mysql + insert into story values + (11,1005,'L05','拜登夸我很帅',854); + ``` + + 6. 《拖拉机大战蜘蛛侠》这篇小说,浏览量涨了100,请更新story表中的相关数据。(2分) + + ```mysql + update story set views_number=views_number+100 where story_name='拖拉机大战蜘蛛侠'; + ``` + +7. 请删除story表的中《皇上滚开本宫只劫财》这篇小说相关数据。(2分) + + ```mysql + delete from story where story_name='皇上滚开本宫只劫财'; + ``` + + 8. 查询 浏览量大于 8000的小说的作者编号和小说作品名称。(2分) + + ```mysql + select * from story where views_number>8000; + ``` + +9. 查询积分大于1000 并且会员等级高于vip03的作家所有信息。(3分) + + ```mysql + select * from author where credits>1000 and vip_id>'vip03'; + ``` + +10. 查询姓名以杜字开头的作家的姓名,积分和等级编号。(3分) + + ```mysql + select author_name,credits,vip_id from author where author_name like '杜%'; + ``` + +11. 查询积分在100、1000之间的作家信息,以积分降序排列。 (3分) + + ```mysql + select * from author where credits between 100 and 1000 order by credits desc; + ``` + +12. 查询出小说的总浏览量,最高浏览量,最小浏览量,平均浏览量,给字段用上中文别名。(3分) + + ```mysql + select sum(views_number) 总浏览量,max(views_number) 最高浏览量,min(views_number) 最小浏览量,avg(views_number) 平均浏览量 from story; + ``` + +13. 查询各种等级的作家的平均积分和作家数量,并对查询结果使用中文别名。(3分) + + ```mysql + select vip_id 作家等级,avg(credits) 平均积分,count(author_name) 作家数量 from author group by vip_id; + ``` + +14. 查询小说数量大于等于2的分类编号和小说数量。(4分) + + ```mysql + select type_id,count(type_id) 小说数量 from story where type_id>='L02' group by type_id; + ``` + +15. 查询所有小说中浏览量最少的书的作品编号、作品名称和类型编号、浏览量。(4分) + + ```mysql + select story_id,story_name,type_id,views_number from story where views_number = (select min(views_number) from story); + ``` + +16. 查询积分比刘产高的作者所有信息。(5分) + + ```mysql + select * from author where credits > (select credits from author where author_name='刘产'); + ``` + +17. 查询出哪些白银作家是没有写小说的,显示这些作家的姓名、等级名称。(8分) + + ```mysql + 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分) + + ```mysql + select * from story where author_id in (select author_id from story where views_number>5000) and views_number<1000; + ``` + +19. 查询所有小说的小说编号、小说名称、浏览量、分类名称、作者姓名、作者积分、作者等级名称,结果字段要用中文别名,并按浏览量降序排列,如果浏览量一样的,再按积分降序排列。(10分) + +```mysql +select a.author_id 小说编号,author_name 小说名称,views_number 浏览量,type_name 分类名称,author_name 作者姓名,credits 作者积分,vip_name 作者等级名称 from vip v right join author a on v.vip_id=a.vip_id right join story s on a.author_id=s.author_id left join type t on s.type_id=t.type_id order by views_number desc,credits desc ; +``` + -- Gitee From 5d548d06a473781c8087886aabff820926c77343 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=B5=96=E5=BF=83=E5=A6=8D?= <2392642810@qq.com> Date: Fri, 10 Mar 2023 14:52:46 +0800 Subject: [PATCH 2/4] =?UTF-8?q?3.09=20=E4=BD=9C=E4=B8=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...50\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" | 0 .../2.17 MySQL\350\257\255\345\217\245.md" | 0 .../2.21 \347\272\246\346\235\237.md" | 0 ...45\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" | 0 .../2.28 \345\205\263\350\201\224\346\237\245\350\257\242.md" | 0 .../3.07 \345\255\220\346\237\245\350\257\242.md" | 0 .../3.09 \344\275\234\344\270\232.md" | 0 7 files changed, 0 insertions(+), 0 deletions(-) rename "03\350\265\226\345\277\203\345\246\215/2.16 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" => "03 \350\265\226\345\277\203\345\246\215/2.16 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" (100%) rename "03\350\265\226\345\277\203\345\246\215/2.17 MySQL\350\257\255\345\217\245.md" => "03 \350\265\226\345\277\203\345\246\215/2.17 MySQL\350\257\255\345\217\245.md" (100%) rename "03\350\265\226\345\277\203\345\246\215/2.21 \347\272\246\346\235\237.md" => "03 \350\265\226\345\277\203\345\246\215/2.21 \347\272\246\346\235\237.md" (100%) rename "03\350\265\226\345\277\203\345\246\215/2.23 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" => "03 \350\265\226\345\277\203\345\246\215/2.23 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" (100%) rename "03\350\265\226\345\277\203\345\246\215/2.28 \345\205\263\350\201\224\346\237\245\350\257\242.md" => "03 \350\265\226\345\277\203\345\246\215/2.28 \345\205\263\350\201\224\346\237\245\350\257\242.md" (100%) rename "03\350\265\226\345\277\203\345\246\215/3.07 \345\255\220\346\237\245\350\257\242.md" => "03 \350\265\226\345\277\203\345\246\215/3.07 \345\255\220\346\237\245\350\257\242.md" (100%) rename "03\350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" => "03 \350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" (100%) diff --git "a/03\350\265\226\345\277\203\345\246\215/2.16 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" "b/03 \350\265\226\345\277\203\345\246\215/2.16 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" similarity index 100% rename from "03\350\265\226\345\277\203\345\246\215/2.16 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" rename to "03 \350\265\226\345\277\203\345\246\215/2.16 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" diff --git "a/03\350\265\226\345\277\203\345\246\215/2.17 MySQL\350\257\255\345\217\245.md" "b/03 \350\265\226\345\277\203\345\246\215/2.17 MySQL\350\257\255\345\217\245.md" similarity index 100% rename from "03\350\265\226\345\277\203\345\246\215/2.17 MySQL\350\257\255\345\217\245.md" rename to "03 \350\265\226\345\277\203\345\246\215/2.17 MySQL\350\257\255\345\217\245.md" diff --git "a/03\350\265\226\345\277\203\345\246\215/2.21 \347\272\246\346\235\237.md" "b/03 \350\265\226\345\277\203\345\246\215/2.21 \347\272\246\346\235\237.md" similarity index 100% rename from "03\350\265\226\345\277\203\345\246\215/2.21 \347\272\246\346\235\237.md" rename to "03 \350\265\226\345\277\203\345\246\215/2.21 \347\272\246\346\235\237.md" diff --git "a/03\350\265\226\345\277\203\345\246\215/2.23 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" "b/03 \350\265\226\345\277\203\345\246\215/2.23 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" similarity index 100% rename from "03\350\265\226\345\277\203\345\246\215/2.23 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" rename to "03 \350\265\226\345\277\203\345\246\215/2.23 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" diff --git "a/03\350\265\226\345\277\203\345\246\215/2.28 \345\205\263\350\201\224\346\237\245\350\257\242.md" "b/03 \350\265\226\345\277\203\345\246\215/2.28 \345\205\263\350\201\224\346\237\245\350\257\242.md" similarity index 100% rename from "03\350\265\226\345\277\203\345\246\215/2.28 \345\205\263\350\201\224\346\237\245\350\257\242.md" rename to "03 \350\265\226\345\277\203\345\246\215/2.28 \345\205\263\350\201\224\346\237\245\350\257\242.md" diff --git "a/03\350\265\226\345\277\203\345\246\215/3.07 \345\255\220\346\237\245\350\257\242.md" "b/03 \350\265\226\345\277\203\345\246\215/3.07 \345\255\220\346\237\245\350\257\242.md" similarity index 100% rename from "03\350\265\226\345\277\203\345\246\215/3.07 \345\255\220\346\237\245\350\257\242.md" rename to "03 \350\265\226\345\277\203\345\246\215/3.07 \345\255\220\346\237\245\350\257\242.md" diff --git "a/03\350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" "b/03 \350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" similarity index 100% rename from "03\350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" rename to "03 \350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" -- Gitee From 55aa883698e53b147d45c09b72e570f7b1b69739 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=B5=96=E5=BF=83=E5=A6=8D?= <2392642810@qq.com> Date: Fri, 10 Mar 2023 14:55:50 +0800 Subject: [PATCH 3/4] =?UTF-8?q?3.09=20=E4=BD=9C=E4=B8=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...50\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" | 0 .../20230217 MySQL\350\257\255\345\217\245.md" | 0 .../20230221 \347\272\246\346\235\237.md" | 0 ...45\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" | 0 .../20230228 \345\205\263\350\201\224\346\237\245\350\257\242.md" | 0 .../20230307 \345\255\220\346\237\245\350\257\242.md" | 0 .../20230309 \344\275\234\344\270\232.md" | 0 7 files changed, 0 insertions(+), 0 deletions(-) rename "03 \350\265\226\345\277\203\345\246\215/2.16 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" => "03 \350\265\226\345\277\203\345\246\215/20230216 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" (100%) rename "03 \350\265\226\345\277\203\345\246\215/2.17 MySQL\350\257\255\345\217\245.md" => "03 \350\265\226\345\277\203\345\246\215/20230217 MySQL\350\257\255\345\217\245.md" (100%) rename "03 \350\265\226\345\277\203\345\246\215/2.21 \347\272\246\346\235\237.md" => "03 \350\265\226\345\277\203\345\246\215/20230221 \347\272\246\346\235\237.md" (100%) rename "03 \350\265\226\345\277\203\345\246\215/2.23 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" => "03 \350\265\226\345\277\203\345\246\215/20230223 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" (100%) rename "03 \350\265\226\345\277\203\345\246\215/2.28 \345\205\263\350\201\224\346\237\245\350\257\242.md" => "03 \350\265\226\345\277\203\345\246\215/20230228 \345\205\263\350\201\224\346\237\245\350\257\242.md" (100%) rename "03 \350\265\226\345\277\203\345\246\215/3.07 \345\255\220\346\237\245\350\257\242.md" => "03 \350\265\226\345\277\203\345\246\215/20230307 \345\255\220\346\237\245\350\257\242.md" (100%) rename "03 \350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" => "03 \350\265\226\345\277\203\345\246\215/20230309 \344\275\234\344\270\232.md" (100%) diff --git "a/03 \350\265\226\345\277\203\345\246\215/2.16 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" "b/03 \350\265\226\345\277\203\345\246\215/20230216 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" similarity index 100% rename from "03 \350\265\226\345\277\203\345\246\215/2.16 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" rename to "03 \350\265\226\345\277\203\345\246\215/20230216 \350\257\255\345\217\245\350\247\204\350\214\203\347\255\211.md" diff --git "a/03 \350\265\226\345\277\203\345\246\215/2.17 MySQL\350\257\255\345\217\245.md" "b/03 \350\265\226\345\277\203\345\246\215/20230217 MySQL\350\257\255\345\217\245.md" similarity index 100% rename from "03 \350\265\226\345\277\203\345\246\215/2.17 MySQL\350\257\255\345\217\245.md" rename to "03 \350\265\226\345\277\203\345\246\215/20230217 MySQL\350\257\255\345\217\245.md" diff --git "a/03 \350\265\226\345\277\203\345\246\215/2.21 \347\272\246\346\235\237.md" "b/03 \350\265\226\345\277\203\345\246\215/20230221 \347\272\246\346\235\237.md" similarity index 100% rename from "03 \350\265\226\345\277\203\345\246\215/2.21 \347\272\246\346\235\237.md" rename to "03 \350\265\226\345\277\203\345\246\215/20230221 \347\272\246\346\235\237.md" diff --git "a/03 \350\265\226\345\277\203\345\246\215/2.23 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" "b/03 \350\265\226\345\277\203\345\246\215/20230223 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" similarity index 100% rename from "03 \350\265\226\345\277\203\345\246\215/2.23 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" rename to "03 \350\265\226\345\277\203\345\246\215/20230223 \346\237\245\350\257\242select\350\257\255\345\217\245\345\222\214\350\277\220\347\256\227\347\254\246.md" diff --git "a/03 \350\265\226\345\277\203\345\246\215/2.28 \345\205\263\350\201\224\346\237\245\350\257\242.md" "b/03 \350\265\226\345\277\203\345\246\215/20230228 \345\205\263\350\201\224\346\237\245\350\257\242.md" similarity index 100% rename from "03 \350\265\226\345\277\203\345\246\215/2.28 \345\205\263\350\201\224\346\237\245\350\257\242.md" rename to "03 \350\265\226\345\277\203\345\246\215/20230228 \345\205\263\350\201\224\346\237\245\350\257\242.md" diff --git "a/03 \350\265\226\345\277\203\345\246\215/3.07 \345\255\220\346\237\245\350\257\242.md" "b/03 \350\265\226\345\277\203\345\246\215/20230307 \345\255\220\346\237\245\350\257\242.md" similarity index 100% rename from "03 \350\265\226\345\277\203\345\246\215/3.07 \345\255\220\346\237\245\350\257\242.md" rename to "03 \350\265\226\345\277\203\345\246\215/20230307 \345\255\220\346\237\245\350\257\242.md" diff --git "a/03 \350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" "b/03 \350\265\226\345\277\203\345\246\215/20230309 \344\275\234\344\270\232.md" similarity index 100% rename from "03 \350\265\226\345\277\203\345\246\215/3.09 \344\275\234\344\270\232.md" rename to "03 \350\265\226\345\277\203\345\246\215/20230309 \344\275\234\344\270\232.md" -- Gitee From bc6c9e8f339796d06d78c20ecb4252c80fc2f156 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=B5=96=E5=BF=83=E5=A6=8D?= <2392642810@qq.com> Date: Fri, 10 Mar 2023 18:31:49 +0800 Subject: [PATCH 4/4] =?UTF-8?q?0310=20=E4=BD=9C=E4=B8=9A?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../20230310 \344\275\234\344\270\232.md" | 188 ++++++++++++++++++ 1 file changed, 188 insertions(+) create mode 100644 "03 \350\265\226\345\277\203\345\246\215/20230310 \344\275\234\344\270\232.md" diff --git "a/03 \350\265\226\345\277\203\345\246\215/20230310 \344\275\234\344\270\232.md" "b/03 \350\265\226\345\277\203\345\246\215/20230310 \344\275\234\344\270\232.md" new file mode 100644 index 0000000..9cf5927 --- /dev/null +++ "b/03 \350\265\226\345\277\203\345\246\215/20230310 \344\275\234\344\270\232.md" @@ -0,0 +1,188 @@ +```mysql +create database zuoye charset utf8; +use zuoye; + +create table stuinfo( + stuno varchar(10), + stuname varchar(10), + stuage int, + stuaddress varchar(10), + stuseat int, + stusex int +); + +insert into stuinfo values +('s2501','张秋利',20,'美国硅谷',1,1), +('s2502','李斯文',18,'湖北武汉',2,0), +('s2503','马文才',22,'湖南长沙',3,1), +('s2504','欧阳俊雄',21,'湖北武汉',4,0), +('s2505','梅超风',20,'湖北武汉',5,1), +('s2506','陈旋风',19,'美国硅谷',6,1), +('s2507','陈风',20,'美国硅谷',7,0); + +create table stuexam( + examno int, + stuno varchar(10), + writtenexam int, + labexam int +); + +insert into stuexam values +(1,'s2501',50,70), +(2,'s2502',60,65), +(3,'s2503',86,85), +(4,'s2504',40,80), +(5,'s2505',70,90), +(6,'s2506',85,90); +``` + +1.查询学生信息表(stuinfo)中所有列信息,给每列取上中文名称 + +```mysql +select stuno 学生学号,stuname 学生姓名,stuage 学生年龄,stuaddress 学生住址,stuseat 学生座号,stusex 学生性别 from stuinfo; +``` + + 2.查询学生信息表(stuinfo)中的姓名,年龄和地址三列的信息 + +```mysql +select stuname,stuage,stuaddress from stuinfo; +``` + + 3.查询学生分数表(stuexam)中的学号,笔试和机试三列的信息,并为这三列取中文名字 + +```mysql +select stuno 学号,writtenexam 笔试,labexam 机试 from stuexam; +``` + + 5.查询学生分数表(stuexam)中的学生的学号,笔试,机试以及总分这四列的信息 + +```mysql +select stuno,writtenexam,labexam,(writtenexam+labexam) from stuexam; +``` + + 6.查询学生信息表(stuInfo)中学生来自哪几个地方 + +```mysql +select distinct stuaddress from stuinfo; +``` + + 7.查询学生信息表(stuInfo)中学生有哪几种年龄,并为该列取对应的中文列名 + +```mysql +select distinct stuage 学生年龄 from stuinfo; +``` + + 8.查询学生信息表(stuInfo)中前3行记录 + +```mysql +select * from stuinfo limit 3; +``` + + 9.查询学生信息表(stuInfo)中前4个学生的姓名和座位号 + +```mysql +select stuname,stuno from stuinfo limit 4; +``` + + 11.将地址是湖北武汉,年龄是20的学生的所有信息查询出来 + +```mysql +select * from stuinfo where stuaddress='湖北武汉' and stuage=20; +``` + + 12.将机试成绩在60-80之间的信息查询出来,并按照机试成绩降序排列 + +```mysql +select * from stuexam where labexam between 60 and 80 order by labexam desc; +``` + + 13.查询来自湖北武汉或者湖南长沙的学生的所有信息 + +```mysql +select * from stuinfo where stuaddress in('湖北武汉','湖南长沙'); +``` + + 14.查询出笔试成绩不在70-90之间的信息,并按照笔试成绩升序排列 + +```mysql +select * from stuexam where writtenexam not between 70 and 90 order by writtenexam ; +``` + + 15.查询年龄没有写的学生所有信息 + +```mysql +select * from stuinfo where stuage is null; +``` + + 16.查询年龄写了的学生所有信息 + +```mysql +select * from stuinfo where stuage is not null; +``` + +17.查询姓张的学生信息 + +```mysql +select * from stuinfo where stuname like '张%'; +``` + +18.查询学生地址中有‘湖’字的信息 + +```mysql +select * from stuinfo where stuaddress like '%湖%'; +``` + +19.查询姓张但名为一个字的学生信息 + +```mysql +select * from stuinfo where stuname like '张_'; +``` + + 20.查询姓名中第三个字为‘俊’的学生的信息,‘俊’后面有多少个字不限制 + +```mysql +select * from stuinfo where stuname like '__俊%'; +``` + + 21.按学生的年龄降序显示所有学生信息 + +```mysql +select * from stuinfo order by stuage desc; +``` + +22.按学生的年龄降序和座位号升序来显示所有学生的信息 + +```mysql +select * from stuinfo order by stuage desc,stuseat asc; +``` + +23.显示笔试第一名的学生的考试号,学号,笔试成绩和机试成绩 + +```mysql +select * from stuexam where writtenexam = (select max(writtenexam) from stuexam); +``` + + 24.显示机试倒数第一名的学生的考试号,学号,笔试成绩和机试成绩 + +```mysql +select * from stuexam where writtenexam = (select min(writtenexam) from stuexam); +``` + +25.查询每个地方的学生的平均年龄 + +```mysql +select stuaddress,avg(stuage) from stuinfo group by stuaddress; +``` + + 26.查询男女生的分别的年龄总和 + +```mysql +select stusex,sum(stuage) from stuinfo group by stusex; +``` + +27.查询每个地方的男女生的平均年龄和年龄的总和 + +```mysql +select stuaddress,stusex,avg(stuage),sum(stuage) from stuinfo group by stuaddress,stusex; +``` + -- Gitee