- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
习题课SQL结构化查询语言概述
SQL主要分成四个部分:
数据定义;
数据操纵;
数据控制;
嵌入式SQL的使用。
; SQL的主要特点
1. 一体化;
2. 两种使用方式,统一的语法结构;
3. 高度非过程化;
4. 语言简洁,易学易用。; 1、基本表的创建
CREATE TABLE SQL 模式名.基本表名
(列名 类型,
……
完整性约束,
……);可用下列语句创建表SC:
CREATE TABLE SC
(SNO CHAR(4) NOT NULL,
CNO CHAR(4) NOT NULL,
GRADE NUMERIC(7,2),
PRIMARY KEY(SNO,CNO),
FOREIGN KEY(SNO)REFERENCES S(SNO),
FOREIGN KEY(CNO)REFERENCES P(CNO),
CHECK(GRADE BETWEEN 0 AND 100));
;2. 视图的创建?
CREATE VIEW 视图名(列名表)
AS SELECT 查询语句
例:在student数据库,建立一个各学院学生情况视图:
CREATE VIEW D_STUDENT(DNAME,SNO,SNAME)
AS (SELECT DNAME,SNO,SNAME
FROM DEPT d,STUDENT S
WHERE D.DNO=S.DNO)
; 3. 索引的创建
CREATE [UNIQUE] INDEX 索引名 ON 基本表名
(列名[序][,列名[序] …); 4. SQL的数据查询
SELECT [DISTINCT] 目标表的列名或列表达式序列
FROM 基本表名(或)视图名序列|表引用
[WHERE 行条件表达式]
[GROUP BY 列名1序列 [HAVING 组条件表达式]]
[ORDER BY 列名2 [ASC|DESC]序列];; 在WHERE子句的行条件表达式中可使用下列运算符:
? 算术比较运算符:<,<=,>,>=,=,<>或!=;
? 逻辑运算符:AND,OR,NOT
? 集合成员资格运算符:IN,NOT IN
? 谓词:EXISTS,ALL,SOME,UNIQUE
? 聚合函数:AVG,MIN,MAX,SUM,COUNT
? 集合运算符:UNION,INTERSECT,EXCEPT
? 空值逻辑判断符:NULL, IS NOT NULL
;集合操作
并 UNION
交 INTERSECT
差 MINUS 或 except
例:查询全校的所有学生(包括本科和研究生)
select sno,sname,age from sudent
union
select g_sno,g_sname,age from graduates;5. SQL的数据更新;目标程序;例1:一个表当做多个表使用
查询家族之间的祖孙关系
Family(parent, child)
Select x.Parent Grand_Parent,
y.Child Grand_Child
From Family x, Family y
where x.child = y. parent
注:同一个表可以当作多个表使用;查询课程选修之间的先选后选关系
requirement(pre_cno,post_cno)
course(cno,cname)
Select x.cname Pre_course ,
y.cname Post_course
from course x, requiement r,
course y
where x.cno=r.pre_cno and
r.post_cno=y.cno;例2:集合运算
一个要注意的例子
查询没有选修 DB 课程的学生
?Select distinct sno,sname
from student s,s_c,cour
文档评论(0)