数据库—DML1(简单查询和复杂查询)

数据库—DML(数据查询)

数据查询使用SELECT(select)语句
SELECT语句的一般形式:

SELECT [ALLDISTINCT] <选择序列>
   FROM <表引用>,, <表引用>
   [WHERE <查询条件>]
   [GROUP BY <分组列> {,<分组列>} [HAVING <分组选择条件>]]
   [ORDER BY <排序列> [ASCDESC] {, <排序列> [ASCDESC]}]
  • 最基本的结构是SELECT-FROM-WHERE,并且SELECT子句和FROM子句是必须的,其他子句都是可选的
  • 数据查询分为不带where的简单查询和带where的复杂查询

简单查询

最简单的SELECT语句是只包括SELECT和FROM子句。这种语句只能完成对单个表的投影运算

SELECT *
FROM Courses;
//查询所有课程的所有信息

PS:用“*”来表示所有的属性列时,得到的查询表的属性次序将和表定义的属性次序一致

SELECT子句中的列可以是表达式

SELECT Sname, 2020year(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为空的学生的学号和课程号
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值