先创建以下3张基本表

1、学生信息表(Student):

2、课程表(Course):

3、成绩表(Score):

4、 将下列数据输入各个表中

建表SQL:

CREATE DATABASE Studentdb;
//学生信息表
CREATE TABLE Student (
Sno char(4) not null PRIMARY KEY,
Sname varchar(8) not null,
Sgender enum ('男','女'),
Sbirth date,
Saddr varchar(50),
Sheight decimal(3,2),
Memo text
) character set utf8; //课程表
CREATE TABLE Course(
Cno char(4) not null,
Cname varchar(50) not null,
Ccredit int
)character set utf8; //成绩表
CREATE TABLE Score (
Sno char(4) not null,
Cno char(4) not null,
Cscore decimal(3,1)
)character set utf8; //插入学生信息表
INSERT INTO Student(Sno,Sname,Sgender,Sbirth,Saddr,Sheight) values
(0001,'刘一平','男','1990-10-1','温州市环城西路201号','1.78'),
(0002,'张得民','男','1990-12-2','杭州市下沙路22号','1.65'),
(0003,'马东','男','1990-7-4','宁波市中山北道20号','1.71'),
(0004,'肖海燕','女','1990-3-15','温州市越秀北路43号','1.65'),
(0005,'张民华','女','1991-5-15','宁波市艮山路7号','1.63'); //插入课程信息
INSERT INTO Course values
(0001,'计算机基础','2'),
(0002,'管理学原理','3'),
(0003,'数据库技术','3'),
(0004,'项目管理','2'),
(0005,'毕业论文','10'); //插入学生成绩信息
INSERT INTO Score values
(0001,0001,80.0),
(0001,0002,90.0),
(0001,0003,70.0),
(0001,0004,85.0),
(0002,0001,78.0),
(0002,0002,NULL),
(0002,0003,77.0),
(0002,0004,67.0),
(0003,0001,66.0),
(0003,0002,76.0),
(0003,0003,NULL),
(0003,0004,73.0);

  

熟练度练习:

1、使用SQL语句修改学生信息表(Student)中字段属性如下:姓名 varchar 20 N    

ALTER table Student MODIFY Sname varchar(20) not null;

2、使用SQL语句删除学生信息表(Student)中“备注”字段

ALTER table Student drop Memo;

3、查询全体学生的详细记录

SELECT * FROM Student;

4、查询学生信息表中学生的姓名和地址信息

SELECT Sname,Saddr FROM Student;

5、查询学生信息表中“刘”姓学生的信息

SELECT * FROM Student where Sname LIKE '刘%';

6、查询学生信息表中姓名含“民”的学生的信息

SELECT * FROM Student where Sname LIKE '%民%'; 

7、查询所有身高1.75以上的男学生的学号和姓名

SELECT Sno,Sname FROM Student where Sgender='男' and Sheight>1.75;

8、查询所有来自“宁波”的学生姓名、性别和年龄

SELECT Sname,Sgender,2020-YEAR(Sbirth) as Sage from Student where Saddr LIKE '%宁波%';

9、查询没有考试成绩的学生学号和课程编号

SELECT Sno,Cno from Score where Cscore is NULL;

10、查询所有参加过考试的学生学号

SELECT DISTINCT(Sno) from Score where Cscore is not null;

11、查询所有学分不小于3的课程名

SELECT Cname from Course where Ccredit>=3;

12、查询学分在1~5范围内的课程编号和课程名

SELECT Cno,Cname FROM Course where Ccredit BETWEEN 1 AND 5;
//
SELECT Cno,Cname FROM Course where Ccredit >=1 and Ccredit <=5;

13、查询“数据库技术”课程的信息

SELECT * FROM Course where Cname='数据库技术';

14、计算“0003”号课程中所有参加过考试的学生平均分

SELECT AVG(Cscore) FROM Score where Cno=0003;

15、查询选修“0002”号课程的学生的成绩最高分

SELECT MAX(Cscore) FROM Score where Cno=0002;

16、统计参加“0001”号课程考试的学生人数

SELECT count(*) FROM Score Where Cno=0001;

17、查询每个学生及其选修课程的情况(包括没有选修课程的学生)

SELECT * FROM Student LEFT OUTER JOIN Score ON (Student.Sno=Score.Sno);  #LEFT OUTER JOIN=LEFT JOIN

18、查询每门选修课以及选修该课程的学生信息

SELECT Course.Cname,Student.* FROM Student,Course where Student.Sno=Course.Cno;

  

  

  

 

  

  

  

  

  

  

  

  

  

  

  

  

 

数据库SQL练习(一):数据查询的更多相关文章

  1. 关系数据库SQL之高级数据查询:去重复、组合查询、连接查询、虚拟表

    前言 接上一篇关系数据库SQL之基本数据查询:子查询.分组查询.模糊查询,主要是关系型数据库基本数据查询.包括子查询.分组查询.聚合函数查询.模糊查询,本文是介绍一下关系型数据库几种高级数据查询SQL ...

  2. 【知识库】-数据库_MySQL之高级数据查询:去重复、组合查询、连接查询、虚拟表

    简书作者:seay 文章出处: 关系数据库SQL之高级数据查询:去重复.组合查询.连接查询.虚拟表 回顾:[知识库]-数据库_MySQL之基本数据查询:子查询.分组查询.模糊查询 Learn [已经过 ...

  3. 数据库SQL的多表查询

    数据库 SQL 的多表查询:eg: table1: employees, table2: departments,table3: salary_grades; 一:内连接: 1):等值连接: 把表em ...

  4. SQL SERVER之数据查询

     本篇主要解说查询语句,全部的演示样例都会依照以下这张表进行. stuID stuName age sex 11090241031 王小虎 21 男 11090241032 王小六 22 男 11 ...

  5. sql多表数据查询

    有时候在sql遇到一次查询多张表的全部数据例如:创建一张虚拟表A ,表A中需要有表B和表C的全部数据(表B和表C并集,如图) 有两种方法一种是使用: 1):union,不过这种查询速度比较慢 /* B ...

  6. SQL语言 之 数据查询

    在Oracle 数据库中,SELECT 语句的基本语法为: SELECT [ALL|DISTINCT] column_name [,expression...] FROM table1_name [, ...

  7. SpringBoot2 整合 ClickHouse数据库,实现高性能数据查询分析

    本文源码:GitHub·点这里 || GitEE·点这里 一.ClickHouse简介 1.基础简介 Yandex开源的数据分析的数据库,名字叫做ClickHouse,适合流式或批次入库的时序数据.C ...

  8. 阿里云RDS数据库sql server 导入数据并添加作业小结

    在阿里云购买ECS服务器和RDS数据库时,要注意网络类型要一致,最好都是VPC,否则ECS不能在内网访问RDS,只能从外网访问:在RDS控制台左侧,数据库安全性的IP白名单中添加ECS外网IP:在数据 ...

  9. 四十二:数据库之SQLAlchemy之数据查询懒加载技术

    懒加载在一对多,或者多对多的时候,如果要获取多的这一部分的数据的时候,通过一个relationship定义好对应关系就可以全部获取,此时获取到的数据是list,但是有时候不想获取全部数据,如果要进行数 ...

  10. MSSQLSERVER数据库- SQL删除重复数据的五种方式

    删除重复的数据,在平时的工作中还是会和碰到的,感觉挺有用,从网上摘录的,记在这里,以备需要时查阅 --方法一,IN方式,适合2000/2005/2008,6728 毫秒 DELETE [student ...

随机推荐

  1. 安全扫描工具Acunetix即AWVS_13.x系列破解版Linux & Windows

    本站所提供工具仅供技术学习交流.请勿用于非法行为.否则后果自负. Acunetix,自动化网络应用安全软件的先驱,已经宣布发布Acunetix第13版.新版本提供了一个改进的用户界面,并引入了创新,如 ...

  2. CommunityServer的编译

    1. 简介 Community Server是一个免费的开源协作系统,用于管理文档.项目.客户关系和电子邮件通信,可以在私有服务器上安装和配置.它的组成分为: 1. OnlyOfficeJabber  ...

  3. redis集群redis-cluster搭建

    redis集群搭建--参考微信公众号(诗情画意程序员):https://mp.weixin.qq.com/s/s5eJE801TInHgb8bzCapJQ 这是来自redis官网的一段介绍,大概意思就 ...

  4. 小白的linux笔记8:linux自动运行爬虫并发送提醒邮件

    有了成功运行的爬虫后,希望能每天定时运行,且遇到错误时能及时发出提醒. 发出提醒 可以用mailx发出邮件做提醒.没有的话先安装Yum install mailx. 以qq邮箱为例,需要设置/etc/ ...

  5. 拍摄UFP 单一职责原则

    3.1 新手机 3.2 拍摄 3.3 没用的东西 3.4 单一职责原则 就一个类而言,应该仅有一个引起它变化的原因, 3.5 方块游戏的设计 如果一个类承担的职责过多,就等于把这些职责耦合在一起,一个 ...

  6. rsa special

    [ReSnAd] -- iqmp ipmq e,c,\(\phi(n)\) 题目: class Key: PRIVATE_INFO = ['P', 'Q', 'D', 'DmP1', 'DmQ1'] ...

  7. 【React Native】集成声网Agora语音通讯

    前言: 公司的产品是一款基于社交的内容聊天软件,需要集成语音通讯功能,在写iOS原生项目时,用到的就是Agora SDK,现在写React Native也直接采用了Agora的库. 集成iOS.And ...

  8. Spring Mvc Http 400 Bad Request问题排查

    如果遇到了Spring MVC报错400,而且没有返回任何信息的情况下该如何排查问题? 问题描述 一直都没毛病的接口,今天测试的时候突然报错400 Bad Request,而且Response没有返回 ...

  9. MS SQL为字段添加说明

    以ms sql server 14  v17为例. 如下表dbo.Q中有一个字段'' 首先在数据库的系统存储过程列表中: 找到sys.sp_addextendedproperty,使用这个为字段添加一 ...

  10. 英语语法 ( Spoken language )

    - - - -------------- 1,五个语序: 主语+谓语(中英语序一致)主语+系动词+表语 (中英语序一致)主语+谓语+宾语(中英语序一致)主语+谓语+间宾+直宾(中英语序一致)主语+谓语 ...