常用的sql语句_第1页
常用的sql语句_第2页
常用的sql语句_第3页
常用的sql语句_第4页
常用的sql语句_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、SQL Server中常用的SQL语句· 1、概述· 2、查询概述· 3、单表查询· 4、连接查询· 5、带有exists的相关子查询· 6、SQL的集合操作· 7、插入操作· 8、删除操作· 9、修改操作· 10、数据定义· 11、视图1、概述名词笛卡尔积、主键、外键数据完整性· 实体完整性:主属性不能为空值,例如选课表中学号和课程号不能为空· 参照完整性:表中的外键取值为空或参照表中的主键· 用户定义完整性:取值范围或非空限制,例如:性别(男女),年龄

2、(0-130)表连接· 自然连接:与等值连接(a.id=b.id)相比,连接后的表只有一列id,而不是两列(a.id和b.id)。· 半连接:与等值连接(a.id=b.id)相比,连接后的表只有A表的列,被B表“多次匹配”列会显示为一行。· 左外连接:left join· 右外连接:right join· 全外连接:full join· 全内连接:inner joinSQL语言的构成· DDL语言:数据定义,定义基本表、视图、索引;· DML语言:数据操纵,查询、增加、修改、删除· DCL语言:权限2、查

3、询概述查询包括:单表查询、连接查询、带有exists的相关子查询、集合操作四中。select.from常用语句执行过程select 投影from table内存where 选取元组group 分组having 选择分组union| 查徇结果的集 合运算select order by 排序输出3、单表查询group by 只有出现在group by子句中的属性,才可出现在select子句中。用order by子句对查询结果按照一个或多个列的值进行升/降排列输出,升序为ASC;降序为desc,空值将作为最大值排序having 与 where的区别· where 决定哪些元组被选择参加运算

4、,作用于关系中的元组· having 决定哪些分组符合要求,作用于分组4、连接查询连接查询包括:多表连接查询、单表连接查询(自连接)、外连接查询、嵌套查询4种连接条件一表名1. 列名1 比较运算符 表名2.列名2连接条件二表名1.列名1 between 表名2.列名2 and 表名2.列名3连接条件中的列名称为连接字段,对应的连接字段应是可比的。执行过程:采用表扫描的方法,在表1中找到第一个元组,然后从头开始扫描表2,查找到满足条件的元组即进行串接并存入结果表中;再继续扫描表2,依次类推,直到表2末尾。再从表1中取第二个元组,重复上述的操作,直到表1中的元组全部处理完毕。4.1 单表

5、连接(自连接)用表别名把一个表定义为两个不同的表进行连接。例:查找至少选修了2号和4号课程的学生的学号select FIRST.snofrom SC as FIRST, SC as SECOND where FIRST.Sno=SECOND.Sno and FIRST.cno='s2' and SECOND.cno='4'4.2 外连接查询外连接查询包括:Left join、right join、full join4.3 嵌套查询· 在select from where语句结构的where子句中可嵌入一个select语句块· 其上层查询称为外

6、层查询或父查询,其下层查询称为内层查询或子查询· SQL语言允许使用多重嵌套查询· 在子查询中不允许使用order by子句· 嵌套查询的实现一般是从里到外,即先进行子查询,再把其结果用于父查询作为条件4.3.1 返回单个值的子查询例:求与“刘力”同一个系的学生名,年龄方法一:select Sname, Sage from student where Sdept = (select sdept from student where Sname = "刘力");方法二:select FIRST.Sname, FIRST.Sage from Stu

7、dent FIRST, Student SECONDwhere FIRST.Sdept = SECOND.Sdept AND SECOND.Sname = "刘力"4.3.2 返回一组值的子查询例:求选修“C6”课程且成绩超过90分的学生方法一:select * from student where sno IN (select sno from SC where Cno="C6" AND Grade>90);方法二(连接查询 ):select student.*from student,SCwhere Student.Sno=SC.Sno AND

8、 Cno="C6" AND Grade>90;例:求比计算机系中某一学生年龄小的其他系的学生方法一:select * from student where sdept!="CS" AND sage < ANY (select Sage from Student where Sdept="CS");方法二:select *from Studentwhere Sdept!=CS AND Sage < (select MAX(Sage) from Student where Sdept="CS");4.

9、3.3 多重子查询例:求D01部门中工资与国贸系中任意职工相同的职工姓名和工资表结构:Teacher(tno, tname, salary, dno)Department(dno, dname)查询语句:select Tname,Salaryfrom Teacherwhere Dno = "D01" AND salary IN( select salary from teacher where Dno =(select DNO from department where Dname="国贸") );例:求工资介于“张三”与“里司”两个之间的职工selec

10、t *from teacherwhere Salary >= (select MIN(Salary) from teacher where Tname IN ("张三", "里司") AND Salary <= (select MAX(Salary) from teacher where Tname IN ("张三", "里司");4.3.4 在from语句中使用子查询,对查询结果定义表名及列名例:求平均成绩超过80分的学号及平均成绩select Sno, avg_Gfrom (select Sno,

11、avg(Grade) from SC group by Sno) AS RA(Sno, avg_G)where avg_G > 80;AS RA(Sno, avg_G),为查询作为定义表名(RA)和列名(Sno, avg_G)5、带有exists的相关子查询· 不相关子查询:子查询的查询条件不依赖于父查询的称为不相关子查询。· 相关子查询:子查询的查询条件依赖于外层父查询的某个属性值的称为相关子查询,带exists 的子查询就是相关子查询· exists表示存在量词,带有exists的子查询不返回任何记录的数据,只返回逻辑值“True” 或“False”例:

12、求所有选修了“C1”课程的学生名。不相关子查询: select Sname from student where sno IN ( select sno from SC where Cno = "C1" ); 相关子查询select Sname from studentwhere exists (select * from SC where student.sno=SC.sno AND Cno = "C1" );相关子查询执行过程:先在外层查询中取student表的第一个元组(记录),用该记录的相关的属性值(在内层where子句中给定的)处理内层查询,若

13、外层的where子句返回TRUE值,则此元组送入结果的表中。然后再取下一个元组;重复上述过程直到外层表的记录全部遍历一次为止。· 不关心子查询的具体内容,因此用 select *· exists + 子查询用来判断该子查询是否返回元组· 当子查询的结果集非空时,exists 为“True”;当子查询的结果集为空时,exists为“False”。· not exists :若子查询结果为空,返回“TRUE”值,否则返回“FALSE”例:查询选修了所有课程的学生的姓名(续)select Snamefrom studentwhere not exists (

14、select * from Course where not exists ( select * from SC where student.sno=SC.sno AND Course.Cno=SC.Cno );例:查询至少选修了S1所选的全部课程的学生名select Snamefrom studentwhere not exists( select * from SC SCX where SCX.sno="s1" AND not exists ( select * from SC SCY where student.sno=SCY.sno AND SCX.Cno=SCY.

15、Cno );6、SQL的集合操作· 属性个数必须一致、对应的类型必须一致· 属性名可以不一致, 最终结果集采用第一个结果的属性名· 缺省为自动去除重复元组,除非显式说明ALL· order by放在整个语句的最后6.1 “并”操作,例:查询计算机系的学生或者年龄不大于19岁的学生,并按年龄倒排序。select * from student where Sdept="CS"UNIONselect * from student where AGE <= 19order by AGE desc6.2 “交”操作,例:查询计算机系的学生

16、并且年龄不大于19岁的学生,并按年龄倒排序。(select * from student where Sdept = "CS") INTERSECT(select * from student where AGE <= 19)order by AGE desc6.3 “差”操作,例:查询选修课程1但没有选修课程2的学生。select Sname, Sdeptfrom studentwhere sno IN ( (select sno from SC where Cno="1") EXCEPT (select sno from SC where Cn

17、o="2") 7、插入操作格式:insert into 表名(列名1,) values (列值1,)插入一已知元组的全部列值insert into student values("2003001", "陈冬", 18, "男", "电商", "管理学院", "徐州");插入一已知元组的部分列值insert into SC(Sno,Cno) values ("2003001", "C003");插入子查询的结果例:设关

18、系S_G(Sno,avg_G),把平均成绩大于80的男生的学号及平均成绩存入S_G中insert into S_G(sno,avg_G) ( select sno, avg(GRADE) from SC where Sno IN (select Sno from Student where SEX="男") group by Sno having avg(GRADE) > 80);8、删除操作格式: delete from 表名 where 条件;· 只能对整个元组操作,不能只删除某些属性上的值· 只能对一个关系(表)起作用,若要从多个关系(表)中

19、删除元组,则必须对每个关系分别执行删除命令9、修改操作update语句一次只能操作一个表。格式1:update 表名 别名set 列名 = 表达式, .where 条件;格式2:update 表名 别名set (列名, .) = (子查询)where 条件;例:工种为SALESMEN的职工的工资改为工种平均工资的110%update EMPLOYEEset Salary = (select 1.1 * avg(Salary) from EMPLOYEE where JOB="SALESMEN")where JOB="SALESMEN" 例:将所有学生的年

20、龄增加1岁update student set Sage=Sage+1; 10、数据定义创建课程表create table SC ( sno CHAR(6) not null, Cno CHAR(6) not null, Grade smallint default null)primary key (sno,Cno)foreign key (sno) references student(sno)foreign key (Cno) references Course(Cno)check (Grade between 0 AND 100);常用的索引:唯一索引和聚簇索引唯一索引· 对于已含重复值的属性列不能建UNIQUE索引· 对某个列建立UNIQUE索引后,插入新记录时DBMS会自动检查新记录在该列上是否取了重复值。这相当于增加了一个U

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论