mysql综合性练习

题目描述

设定有一个数据库,里面有4张表:

  • 学生表(student)
  • 课程表(course)
  • 成绩表(score)
  • 教师信息表(teacher)

表结构如下:

表一_学生表(student)

属性名数据类型含 义
snoint学号(主键)
snamevarchar学生姓名
ssexvarchar学生性别
sbirthdaydate学生出生年月
classidvarchar学生所在班级

 

表二_课程表(course)

 

属性名数据类型含 义
cnovarchar课程号(主键)
cnamevarchar课程名称
tnoint教师编号(外键)

表三_成绩表(score)

属性名数据类型含 义
snoint学号(外键)
cnovarchar课程号(外键)
sdegreefloat成绩

表四_教师表(teacher)

属性名数据类型含 义
tnoint编号(主键)
tnamevarchar教师姓名
tsexvarchar教师性别
tbirthdaydate教师出生年月
professionalvarchar职称
departmentvarchar教师所在部门

二、创建数据库和表

先创建数据库mysql_test,并且设置这个数据库的编码字符集为utf-8。

 

 学生表:

create table student(
    sno  int(10),
    sname varchar(10),
    ssex varchar(10),
    sbirthday date,
    classid varchar(10)
);

alter table student add primary key(sno);

 

 教师表:

create table teacher(
    tno int(10),
    tname varchar(12),
    tsex varchar(10),
    tbirthday date,
    professional varchar(20),
    department varchar(20)
);

alter table teacher add primary key(tno);

 

课程表:

create table course(
    cno varchar(10),
    cname varchar(20),
    tno int(10)
);

alter table course add primary key(cno);
alter table course add constraint fk_course_teacher foreign key(tno) references teacher(tno); 

 

成绩表:

create table score(
    sno int(10),
    cno varchar(10),
    sdegree float(5)
);

alter table score add constraint fk_score_student foreign key(sno) references student(sno);
alter table score add constraint fk_score_course foreign key(cno) references course(cno);

 

三、添加数据

insert into student (sno,sname,ssex,sbirthday,classid) 
values(108,'曾华','','1996-9-1','95033'),(105,'匡明','','1995-10-2','95031'),
(107,'王丽','','1996-1-23','95033'),(101,'李军','','1996-2-20','95033'),
(109,'王芳','','1995-2-10','95031'),(103,'陆君','','1994-6-3','95031');


insert into teacher(tno,tname,tsex,tbirthday,professional,department) 
values(804,'李诚','','1978-12-2','副教授','计算机系'),
(856,'张旭','','1979-3-12','讲师','电子工程系'),
(825,'王萍','','1982-5-5','助教','计算机系'),
(831,'刘冰','','1984-8-14','助教','电子工程系');


insert into course(cno,cname,tno) 
values('3-105','计算机导论',825),('3-245','操作系统',804),
('6-166','数字电路',856),('9-888','高等数学',831);


insert into score(sno,cno,sdegree) values
(103,'3-245',86),
(105,'3-245',75),
(109,'3-245',68),
(103,'3-105',92),
(105,'3-105',88),
(109,'3-105',76),
(101,'3-105',64),
(107,'3-105',91),
(108,'3-105',78),
(101,'6-166',85),
(107,'6-166',79),
(108,'6-166',81);

学生表:

 

教师表:

 

 课程表:

 

 

 成绩表:

四、SQL题目

1、查询所有学生的姓名,性别及班级编号

 

 

 2、查询教师所有的部门名称(即不重复的DEPART列)

3、查询student表的所有记录

 

 4、查询score表中成绩在60到80之间的所有记录

 

 5、查询score表中成绩为85,86或88的记录

 

 6、查询student表中班级编号为"95031"或性别为"女"的同学记录

 

 7、查询student表的所有记录,以班级编号降序排列

 

 8、查询score表的所有记录,先按照cno升序排列,若相同则按照sdegree降序排列

 

 9、查询班级编号为"95031"班级的学生人数

 

 10、查询score表中的最高分的学生学号和课程号

 

 11、查询编号为"3-105"的课程平均分

 

 12、查询score表中至少有5名学生选修的并以3开头的课程的平均分数

 

 13、查询每科成绩均在70到90之间的学生编号

 注意:having 后面只能跟聚合函数,如avg、min、max、sum等聚合函数

 14、查询所有学生的姓名,所选课程编号和成绩

 

 

 15、查询所有学生的学号,所选课程名和成绩

 

 

 16、查询所有学生的姓名,所选课程名和成绩

 

 

 17、查询"95033"班同学所选每个课程的平均分

 

 

 18、假设使用如下命令建立了一个GRADE表:

CREATE TABLE GRADE(
LOW INT(3),
UPP INT(3),
RANK VARCHAR(1)
);
INSERT INTO GRADE VALUES(90,100,'A');
INSERT INTO GRADE VALUES(80,89,'B');
INSERT INTO GRADE VALUES(70,79,'C');
INSERT INTO GRADE VALUES(60,69,'D');
INSERT INTO GRADE VALUES(0,59,'E');

– 现查询所有同学的学号,所选课程号和等级(RANK列)

 

 19、查询"3-105"课程的成绩高于学号为109同学这科成绩的所有同学记录

 

 20、查询1995年之后出生的所有学生所选学的课程名及成绩

 

 

 

 21、查询与学号108同学同年出生的所有学生的学号,姓名和生日

 

 

 22、查询"张旭"教师任课的学生成绩

 

 

 23、查询选修某课程的同学人数多于5人的教师姓名

 

 

 24、查询"95033"班和"95031"班全体学生的记录

 

 

 25、查询存在有85分以上成绩的课程编号

 

 

 26、查询出"计算机系"教师所教课程每一科成绩的平均分

 

 

 27、查询"计算机系"与"电子工程系"不同职称的教师的姓名和职称

 

 

28、查询所有教师和同学的姓名,性别和生日

 

 

 29、查询所有"女"教师和"女"同学的姓名,性别和生日

 

 

 30、查询所有任课教师的姓名和部门

 

 

 31、查询所有未讲课的教师的姓名和部门

 

 

 32、查询student表中不姓"王"的同学记录

 

 

 33、查询student表中每个学生的姓名和年龄

 

 

 34、查询student表中最大和最小的生日值

 

 

 35、查询student表中的全部记录,按照班级编号降序排列,班级编号若相同则按照生日降序排列

 

 

 36、查询所有"男"教师及其所上的课程名称

 

 

 37、查询和"李军"同性别并同班的同学信息

 

 

 38、查询所有选修"计算机导论"课程的"男"同学的成绩表

 

 

 39、查询出同时选择"3-245"和"3-105"的课程的学生信息

 

 

 

40、查询既没有选修"3-245"课程也没有选修"3-105"课程的学生信息

 

 

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
题目名称 linux实验-基本指令1 题目关键字 linux实验-基本指令1 题目录入时间 2013-4-1 22:36:02 题目内容 1、root帐号登录,查看/tmp目录,如果/tmp目录下没有子目录myshare,则建立该目录。 2、创建帐号testuser。 3、把myshare目录及其目录下的所有文件和子目录的拥有者该为testuser,工作组改为users。 4、切换至testuser帐号。进入/tmp/myshare目录,采用vim编辑器编写以上程序,程序名称为hello.sh: #!/bin/bash echo "app start" echo -e func (){ echo "hello world!" } func echo -e echo "app end" 5、保存hello.sh后,给予hello.sh拥有者可读、可写和可执行的权限,同组可读可执行,其他人可执行权限。 6、输入./hello.sh,观察程序输出的效果。 7、进入testuser的用户主目录,在这个目录下创建hello.sh的软链接,同时拷贝hello.sh到该目录下并改名为hello.sh.bak,要求拷贝时保留文件属性值。 8、退出testuser帐号,回到root帐号,从/开始查找后缀名为.conf的所有文件,把输出结果重定向到testuser帐号的主目录下的output.txt文件。 9、在上一步操作的.conf文件中找出文件容量最大的和最小那个,并把这两个文件的容量大小输出到output.txt文件中。 10、统计出系统中有多少个用户帐号,把数量输出到output.txt文件中。 11、把output.txt文件转换为windows记事本可正规打开的格式。 12、tar打包压缩testuser帐号主目录下的所有文件。 13、用U盘把上一步打包压缩文件拷贝到U盘上。 14、执行userdel -r testuser,执行rm -fr myshare 题目创建人 题目注释 把打包压缩文件提交即可。 题目名称 linux-课题练习1 题目关键字 linux-课题练习1 题目录入时间 2013-4-15 12:21:53 题目内容 1、创建组testgroup; 2、创建用户a2012,先采用默认设置创建,然后使该用户加入testgroup组。 3、创建用户a2013,其用户主目录为/tmp/a2013,其主组为testgroup,附加组为users。 4、用id命令显示a2012和a2013用户信息,并且把这些信息记录到日志文件/tmp/test.log中。 5、参考书本98-99页crontab命令内容,使用root执行crontab -e,编写时程表,完成每隔5分钟把当前时间追加进/tmp/test.log中。 6、执行crontab -l,把输出内容追加进/tmp/test.log。 7、待完成2次时间记录追加后,执行crontab -r删除当前的时程表。 8、把/tmp/test.log拷贝到windows中(注意文本格式的转换),采用记事本打开,看是否看到完整内容。 题目创建人 题目注释 课题练习,做完后直接把test.log文件提交上来。 题目名称 linux课后作业1 题目关键字 linux课后作业1 题目录入时间 2013-5-6 10:23:32 题目内容 完成课本实验6第一题:菜单驱动程序。 题目创建人 题目注释 本题为当天提交,把程序文件以附件形式提交即可。 题目名称 linux shell程序设计实验1 题目关键字 linux shell程序设计实验1 题目录入时间 2013-5-6 10:25:36 题目内容 完成课本实验6的第2题,要有输入错误处理。 题目创建人 题目注释 把程序文件以附件形式提交即可。 题目名称 linux shell程序设计实验2 题目关键字 linux shell程序设计实验2 题目录入时间 2013-5-6 10:26:43 题目内容 按要求完成课本实验7。 题目创建人 题目注释 把3个程序文件打包提交即可。 题目名称 linux gcc实验 题目关键字 linux gcc实验 题目录入时间 2013-5-20 14:27:52 题目内容 课本实验8第2题 题目创建人 题目注释 请提交Makefile文件 题目名称 Linux下MYSQL操作 题目关键字 MYSQL实验 题目录入时间 2015-4-15 11:19:01 题目内容 1、在Linux下检查是否有mysql,如果没有,请安装。版本上必须是5.5以上,越新越好! 2、在mysql下创建数据库,名称为 testdb,内有表 linuxtest,表字段如下: userid (自己的学号),varchar 50,关键字 mysql_version (当前mysql版本号), varchar 50 linux_version (当前发行版的uname -a 返回值),varchar 100 eth0_HW (eth0物理地址),varchar 50 3、insert对应的数据到表 linuxtest 4、导出该数据库的sql文件,命名为 学号.sql 5、提交该sql文件 题目创建人 题目注释 题目名称 Linux网络实验1-wget+lynx 题目关键字 Linux网络实验1-wget+lynx 题目录入时间 2015-4-20 21:46:19 题目内容 1、让你的linux接入互联网,如果你是虚拟机安装,可以采用桥接本地网卡的方式上网(课堂上有介绍该方法)。如果你是独立安装linux请自行解决。配置好IP地址和网关,DNS设置两个(8.8.8.8和114.114.114.114)。 2、已root登录系统,创建目录webtest,进入webtest目录,分别把ifcfg-eth0文件及resolv.conf文件内容追加至result.txt,。 3、执行echo "1234567890这是分隔线0987654321" >> result.txt traceroute www.scau.edu.cn >> result.txt 4、执行wget http://www.baidu.com 5、以源码方式安装lynx 官方网站:http://lynx.isc.org/ 下载地址:http://lynx.isc.org/current/ 请选择最新版本 安装示例: wget http://lynx.isc.org/current/lynx2.8.8rel.2.tar.gz 解压lynx2.8.8rel.2.tar.gz 进入解压后的目录 依次执行 ./configure make make install 6、echo "1234567890这是分隔线0987654321" >> result.txt 7、执行whereis lynx >> result.txt 8、echo "1234567890这是分隔线0987654321" >> result.txt 9、lynx -dump http://www.baidu.com >> result.txt 10、提交result.txt文件 题目创建人 题目注释 题目名称 GTK+实验 题目关键字 GTK+实验 题目录入时间 2015-5-24 13:47:12 题目内容 GTK+实验,完成课本实验9,最后打包上传(程序源代码+可运行文件) 题目创建人 题目注释 题目名称 决战Linux(1) 题目关键字 LAMP LNMP 题目录入时间 2015-4-28 22:16:03 题目内容 在LAMP、LNMP等环境下,任意挑选下列2种或以上动态网页语言,写出一个页面,读取MYSQL实验中的数据表数据。 (PHP,JSP,Perl,Python,Ruby,Go,ASP.NET) 注意:不同的动态网页语言,所要求的具体环境有可能不同,需要自行搭建。 该实验为综合性实验,最终需要提交综合性实验报告。报告提纲大致如下: 1、实验步骤描述(有图有真像) (1)第一种动态语言 a、实验环境描述 b、系统架构图 c、相关配置总结 d、核心代码总结 e、页面效果截图 (2)第二种动态语言 (3)第三种动态语言 以下同。 2、实验总结(有对比有分析有感想) 题目创建人 题目注释
MySQL全方位练习是指对MySQL数据库进行全面的实践和练习,包括数据库的设计、创建、查询、更新和管理等方面的操作。 首先,我们可以从数据库的设计和创建开始练习。根据具体需求,我们可以创建一个数据库,并设计合适的表结构,包括表的字段、数据类型、约束条件等。这个过程可以通过使用MySQL提供的CREATE DATABASE和CREATE TABLE语句来实现。 接下来,我们可以练习使用SQL语句进行查询操作。SQL是结构化查询语言,可以方便地进行数据库的查询。我们可以练习使用SELECT语句查询表中的数据,并使用WHERE子句对数据进行筛选。此外,还可以练习使用JOIN语句进行多表连接查询。 另外,我们还可以练习使用SQL语句进行数据的更新操作。比如,可以学习使用INSERT语句向表中插入数据,使用UPDATE语句更新表中的数据,使用DELETE语句删除表中的数据等。 此外,还可以练习使用SQL语句进行数据的管理操作。比如,可以学习使用ALTER TABLE语句修改表结构,使用DROP TABLE语句删除表,使用GRANT和REVOKE语句设置和取消用户权限等。 在进行全方位练习的过程中,可以结合实际应用场景,找到一个具体的项目或需求,并将其实现。可以模拟一个电商网站的用户管理系统,练习用户信息的插入、查询和更新;可以模拟一个图书管理系统,练习图书信息的添加、修改和删除等。通过这样的实践,不仅能够加深对MySQL的理解,还能够提升自己的数据库操作能力。 总之,MySQL全方位练习是一个系统性的学习过程,通过设计、创建、查询、更新和管理等方面的实践,可以全面提高对MySQL数据库的理解和应用能力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值