数据库—DML(数据查询)
数据查询使用SELECT(select)语句
SELECT语句的一般形式:
SELECT [ALL︱DISTINCT] <选择序列>
FROM <表引用>, …, <表引用>
[WHERE <查询条件>]
[GROUP BY <分组列> {,<分组列>} [HAVING <分组选择条件>]]
[ORDER BY <排序列> [ASC︱DESC] {, <排序列> [ASC︱DESC]}]
- 最基本的结构是SELECT-FROM-WHERE,并且SELECT子句和FROM子句是必须的,其他子句都是可选的
- 数据查询分为不带where的简单查询和带where的复杂查询
简单查询
最简单的SELECT语句是只包括SELECT和FROM子句。这种语句只能完成对单个表的投影运算
SELECT *
FROM Courses;
//查询所有课程的所有信息
PS:用“*”来表示所有的属性列时,得到的查询表的属性次序将和表定义的属性次序一致
SELECT子句中的列可以是表达式
SELECT Sname, 2020﹣year(Birthday) AS Age
FROM Students;
//查询Students表中学生的姓名和出生年份,并将 2020﹣year(Birthday)重命名为Age和Sname一起输出
SELECT后可以使用集合量词ALL或DISTINCT,缺省时为ALL
ALL不删除结果的重复行,而DISTINCT将删除结果中的重复行
ALL或DISTINCT作用于所有列而不是一个列
SELECT DISTINCT Cno,Grade
FROM SC;
//查询选修课程的各种成绩
复杂查询
复杂查询都需要使用WHERE字句说明查询条件
where字句的常用形式:
表达式形式 | 谓词 |
---|---|
比较表达式 | <、<=、>、>=、=、<>或!= |
BETWEEN表达式 | BETWEEN AND, NOT BETWEEN AND |
IN表达式 | IN,NOT IN |
LIKE表达式 | LIKE,NOT LIKE |
NULL表达式 | IS NULL,IS NOT NULL |
存在表达式 | EXIST,NOT EXIST |
唯一表达式 | UNIQUE |
比较表达式
- 比较表达式的常见形式:<值表达式1>&<值表达式2>
- 其中&是比较运算符(<、<=、>、>=、=、<>或!=)
- <值表达式1>和<值表达式2>都是可求值的表达式,并且它们的值可以进行比较。
eg:
SELECT Tname, Sex
FROM Teachers
WHERE Title = ‘讲师’;
//在表Teachers中查询Title=讲师的并输出他们的姓名和性别
BETWEEN表达式
- 判定一个给定的值是否在给定的闭区间,其最常见形式是:
- <值表达式> [NOT] BETWEEN <下界> AND <上界>
- <下界>的值小于或等于<上界>
- 当且仅当<值表达式>的值在<下界>和<上界>确定的闭区间时
- <值表达式> BETWEEN <下界> AND <上界>为真
- <值表达式> NOT BETWEEN <下界> AND <上界>为假
eg:
SELECT Sname, Speciality
FROM Students
WHERE year(Birthday) BETWEEN 1997 AND 1999;
//在表Students中选择生日的年份位于1997和1999年之间的学生并输出他们的Sname和Speciality
- BETWEEN-AND和NOT BETWEEN-AND表示的条件一般都可以用AND或OR连接的多重比较表示
SELECT Sname, Speciality
FROM Students
WHERE year(Birthday)>=1997 AND year(Birthday)<=1999;
//在表Students中选择生日的年份位于1997和1999年之间的学生并输出他们的Sname和Speciality
IN表达式
- 判定一个给定的元素是否在给定的集合中,IN表达式有两种形式:
- <值表达式> [NOT] IN (<值表达式列表>)
- <元组>| [NOT] IN <子查询>
- 在第一种形式中,<值表达式>是可求值的表达式(通常是属性),而<值表达式列表>包括一个或多个可求值的表达式(通常是字面值,如45,‘教授’等),中间用逗号隔开
- 当且仅当<值表达式>的值出现在<值表达式列表>中, <值表达式> IN (<值表达式列表>)为真, 而<值表达式> NOT IN
(<值表达式列表>)为假
eg:
SELECT Sno, Sname
FROM Students
WHERE Speciality IN (‘计算机科学与技术’, ‘软件工程’);
//查询Students表中Speciality等于计算机科学与技术和软件工程的并输出他们的学号和姓名
LIKE表达式
- LIKE表达式允许进行模糊查询
- LIKE表达式的一般形式为: [NOT] LIKE <匹配串> [ESCAPE ‘<换码字符>’]
- <匹配串>是给定的字符串常量,允许使用通配符。
- 有两种通配符: “_”(下横线)可以与任意单个字符匹配
- “%”可以与零个或多个任意字符匹配
- ESCAPE ‘<换码字符>’用于定义转义字符,将紧随其后的一个字符转义
eg:
SELECT Cname
FROM Courses
WHERE Cname LIKE ‘数据%’;
//在表Courses中查询课程名以数据开头的并输出这些课程名
SELECT Sno, Sname
FROM Students
WHERE Sname LIKE ‘李_ _’;
//在表Student里查找李姓且姓名只有两个字的学生并输出其学号和姓名
PS:一个汉字占两个字符位置
SELECT *
FROM Courses
WHERE Cname LIKE ‘C\_%’ ESCAPE ‘\’;
//在表Courses中查询Cname以C_开头的所有课程并输出此课程的所有信息(*)
- 由于通配符“_”出现在模式中,我们需要使用转义字符将它转义。 其中,ESCAPE
- 短语定义“\”为转义字符,模式‘C_%’中的“_”被转义,不再取通配符含义,而是取字面意义。
- 注意:‘C_%’中的“%”仍然是通配符,因为转义字符只对紧随其后的一个字符转义
NULL表达式 - SQL允许元组的某些属性上取空值(NULL)。空值代表未知的值,不能与其他值进行比较,NULL表达式允许我们判定给定的值是否为空值。
- NULL表达式的常见形式如下: <值表达式> | <子查询> IS [ NOT ] NULL
- 如果A是属性,则A IS NULL 为真当且仅当属性A上取空值
SELECT Sno, Cno
FROM SC
WHERE Grade IS NULL;
//在表SC中查询Grade为空的学生的学号和课程号