ImageVerifierCode 换一换
格式:DOCX , 页数:20 ,大小:28.20KB ,
资源ID:20196942      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/20196942.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(SQL语句学习手册实例版Word格式文档下载.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

SQL语句学习手册实例版Word格式文档下载.docx

1、(1)选用 CASCADE,即当删除数据库模式时,则本数据库模式和其下属的基本表、视图、索引等全部被删除。(2)选用 RESTRICT,即本数据库模式下属的基本表、视图、索引等事先已清除,才能删除本数据库模式,否则拒绝删除。)DROP SCHEMA TEACHING_DB CASCADE 单表操作 例 16 找出 3 个学分的课程号和课程名。SELECT CNO,CNAME FROM COURSES WHERE CREDIT 3 例 17 查询年龄大于 22 岁的学生情况。SELECT*FROM STUDENTS WHERE AGE 22 例 18 找出籍贯为河北的男生的姓名和年龄。SELEC

2、T SNAME,AGE FROM STUDENTS WHERE BPLACE 河北 AND SEX 男 例 19 找出年龄在 20 23 岁之间的学生的学号、姓名和年龄,并按年龄升序排序。(ASC(升序)或 DESC(降序)声明排序的方式,缺省为升序。)SELECT SNO,SNAME,AGE FROM STUDENTS WHERE AGE BETWEEN 20 AND 23 ORDER BY AGE 例 20 找出年龄小于 23 岁、籍贯是湖南或湖北的学生的姓名和性别。(条件比较运算符、和逻辑运算符 AND(与),此外还可以使用的运算符有:(大于)、(大于等于)、(小于等于)、(不等于)、N

3、OT(非)、OR(或)等。谓词 LIKE 只能与字符串联用,常常是“列名 LIKE pattern”的格式。特殊字符“_”和“%”作为通配符。谓词 IN 表示指定的属性应与后面的集合(括号中的值集或某个查询子句的结果)中的某个值相匹配,实际上是一系列的 OR(或)的缩写。谓词 NOT IN 表示指定的属性不与后面的集合中的某个值相匹配。谓词 BETWEEN 是“包含于 之中”的意思。)SELECT SNAME,SEX FROM STUDENTS WHERE AGE 23 AND BPLACE LIKE 湖 或 SELECT SNAME,SEX FROM STUDENTS WHERE AGE 2

4、3 AND BPLACE IN(湖南 ,湖北 )例 22 找出学生表中籍贯是空值的学生的姓名和性别。(在 SQL 中不能使用条件:列名 NULL。在 SQL 中只有一个特殊的查询条件允许查询 NULL 值:)SELECT SNAME,SEX FROM STUDENTS WHERE BPLACE IS NULL 多表操作 例 23 找出成绩为 95 分的学生的姓名。(子查询)SELECT SNAME FROM STUDENTS WHERE SNO (SELECT SNO FROM ENROLLS WHERE GRADE 95)例 24 找出成绩在 90 分以上的学生的姓名。SELECT SNAM

5、E FROM STUDENTS WHERE SNO IN (SELECT SNO FROM ENROLLS WHERE GRADE 90)或 SELECT SNAME FROM STUDENTS WHERE SNO ANY (SELECT SNO FROM ENROLLS WHERE GRADE 90)例 25 查询全部学生的学生名和所学课程号及成绩。(连接查询)SELECT SNAME,CNO,GRADE FROM STUDENTS,ENROLLS WHERE STUDENTS.SNO ENROLLS.SNO 例 26 找出籍贯为山西或河北,成绩为 90 分以上的学生的姓名、籍贯和成绩。(当

6、构造多表连接查询命令时,必须遵循两条规则。第一,连接条件数正好比表数少 1(若有三个表,就有两个连接条件);第二,若一个表中的主关键字是由多个列组成,则对此主关键字中的每一个列都要有一个连接条件(也有少数例外情况)SELECT SNAME,BPLACE,GRADE FROM STUDENTS,ENROLLS WHERE BPLACE IN(山西 ,河北)AND GRADE 90 AND STUDENTS.SNO=ENROLLS.SNO 例 28 查出课程成绩在 80 分以上的女学生的姓名、课程名和成绩。(FROM 子句中的子查询)SELECT SNAME,CNAME,GRADE FROM (S

7、ELECT SNAME,CNAME,GRADE FROM STUDENTS,ENROLLS,COURSES WHERE SEX 女)AS TEMP(SNAME,CNAME,GRADE)WHERE GRADE 80 表达式与函数的使用 例 29 查询各课程的学时数。(算术表达式由算术运算符、*、与列名或数值常量所组成。)SELECT CNAME,COURSE_TIME CREDIT*16 FROM COURSES 例 30 找出教师的最小年龄。(内部函数:SQL 标准中只使用 COUNT、SUM、AVG、MAX、MIN 函数,称之为聚集函数(Set Function)。COUNT 函数的结果是该

8、列统计值的总数目,SUM 函数求该列统计值之和,AVG 函数求该列统计值之平均值,MAX 函数求该列最大值,MIN 函数求该列最小值。)SELECT MIN(AGE)FROM TEACHERS 例 31 统计年龄小于等于 22 岁的学生人数。(统计)SELECT COUNT(*)FROM STUDENTS WHERE AGE=3 相关子查询 例 37 查询没有选任何课程的学生的学号和姓名。(当一个子查询涉及到一个来自外部查询的列时,称为相关子查询(Correlated Subquery)。相关子查询要用到存在测试谓词 EXISTS 和 NOT EXISTS,以及 ALL、ANY(SOME)等。

9、)SELECT SNO,SNAME FROM STUDENTS WHERE NOT EXISTS (SELECT*FROM ENROLLS WHERE ENROLLS.SNO=STUDENTS.SNO)例 38 查询哪些课程只有男生选读。SELECT DISTINCT CNAME FROM COURSES C WHERE 男 ALL (SELECT SEX FROM ENROLLS,STUDENTS WHERE ENROLLS.SNO=STUDENTS.SNO AND ENROLLS.CNO=C.CNO)例 39 要求给出一张学生、籍贯列表,该表中的学生的籍贯省份,也是其他一些学生的籍贯省份。

10、SELECT SNAME,BPLACE FROM STUDENTS A WHERE EXISTS (SELECT*FROM STUDENTS B WHERE A.BPLACE=B.BPLACE AND A.SNO B.SNO)例 40 找出选修了全部课程的学生的姓名。本查询可以改为:查询这样一些学生,没有一门课程是他不选修的。SELECT SNAME FROM STUDENTS WHERE NOT EXISTS (SELECT*FROM COURSES WHERE NOT EXISTS (SELECT*FROM ENROLLS WHERE ENROLLS.SNO STUDENTS.SNO AN

11、D ENROLLS.CNO COURSES.CNO)关系代数运算 例 41 设有某商场工作人员的两张表:营业员表 SP_SUBORD 和营销经理表 SP_MGR,其关系数据模式如下:SP_SUBORD(SALPERS_ID,SALPERS_NAME,MANAGER_ID,OFFICE)SP_MGR(SALPERS_ID,SALPERS_NAME,MANAGER_ID,OFFICE)其中,属性 SALPERS_ID 为工作人员的编号,SALPERS_NAME 为工作人员的姓名,MANAGER_ID 为所在部门经理的编号,OFFICE 为工作地点。若查询全部商场工作人员,可以用下面的 SQL 语句

12、:(SELECT*FROM SP_SUBORD)UNION (SELECT*FROM SP_MGR)或等价地用下面的 SQL 语句:SELECT*FROM(TABLE SP_SUBORD UNION TABLE SP_MGR)(2)INTERSECT (SELECT*FROM SP_SUBORD)INTERSECT (SELECT*FROM SP_MGR)或等价地用下面的 SQL 语句:SELECT*FROM(TABLE SP_SUBORD INTERSECT TABLE SP_MGR)或用带 ALL 的 SQL 语句:(SELECT*FROM SP_SUBORD)INTERSECT ALL

13、(SELECT*FROM SP_MGR)或 SELECT*FROM(TABLE SP_SUBORD INTERSECT ALL TABLE SP_MGR)(3)EXCEPT (SELECT*FROM SP_MGR)EXCEPT (SELECT*FROM SP_SUBORD)或等价地用下面的 SQL 语句:SELECT*FROM(TABLE SP_MGR EXCEPT TABLE SP_ SUBORD)或用带 ALL 的 SQL 语句:(SELECT*FROM SP_MGR)EXCEPT ALL (SELECT*FROM SP_SUBORD)例 42 查询籍贯为四川、课程成绩在 80 分以上的学

14、生信息及其成绩。(自然连接)(SELECT*FROM STUDENTS WHERE BPLACE=四川)NATURAL JOIN (SELECT*FROM ENROLLS WHERE GRADE=80)例 3.43 列出全部教师的姓名及其任课的课程号、班级。(外连接与外部并外连接允许在结果表中保留非匹配元组,空缺部分填以 NULL。外连接的作用是在做连接操作时避免丢失信息。外连接有 3 类:(1)左外连接(Left Outer Join)。连接运算谓词为 LEFT OUTER JOIN,其结果表中保留左关系的所有元组。(2)右外连接(Right Outer Join)。连接运算谓词为 RIGH

15、T OUTER JOIN,其结果表中保留右关系的所有元组。(3)全外连接(Full Outer Join)。连接运算谓词为 FULL OUTER JOIN,其结果表中保留左右两关系的所有元组。)SELECT TNAME,CNO,CLASS FROM TEACHERS LEFT OUTER JOIN TEACHING USING(TNO)SQL 的数据操纵 例 44 把教师李映雪的记录加入到教师表 TEACHERS 中。(插入)INSERT INTO TEACHERS VALUES(1476,李映雪 ,44,副教授)例 45 成绩优秀的学生将留下当教师。INSERT INTO TEACHERS(

16、TNO,TNAME)SELECT DISTINCT SNO,SNAME FROM STUDENTS,ENROLLS WHERE STUDENTS.SNO ENROLLS.SNO AND GRADE 90 例 47 把所有学生的年龄增加一岁。(修改)UPDATE STUDENTS SET AGE AGE+1 例 48 学生张春明在数据库课考试中作弊,该课成绩应作零分计。UPDATE ENROLLS SET GRADE 0 WHERE CNO C1 AND 张春明 (SELECT SNAME FROM STUDENTS WHERE STUDENTS.SNO=ENROLLS.SNO)例 49 从教师

17、表中删除年龄已到 60 岁的退休教师的数据。(删除)DELETE FROM TEACHERS WHERE AGE 60 SQL 的数据控制 例 50 授予 LILI 有对表 STUDENTS 的查询权。(表视图特权的授予 一个 SQL 特权允许一个被授权者在给定的数据库对象上进行特定的操作。授权操作的数据库对象包括:表/视图、列、域等。授权的操作包括:INSERT、UPDATE、DELETE、SELECT、REFERENCES、TRIGGER、UNDER、USAGE、EXECUTE 等。其中 INSERT、UPDATE、DELETE、SELECT、REFERENCES、TRIGGER 有对表做

18、相应操作的权限,故称为表特权。)GRANT SELECT ON STUDENTS TO LILI WITH GRANT OPTION 例 51 取消 LILI 的存取 STUDENTS 表的特权。REVOKE ALL ON STUDENTS FROM LILI CASCADE 不断补充中:1.模糊查找:它判断列值是否与指定的字符串格式相匹配。可用于 char、varchar、text、ntext、datetime和 smalldatetime 等类型查询。可使用以下通配字符:百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%。下划线_:匹配单个任意字符,它常用来限制表达式的

19、字符长度。方括号:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。:其取值也 相同,但它要求所匹配对象为指定字符以外的任一个字符。例如:限制以 Publishing结尾,使用 LIKE%Publishing 限制以 A开头:LIKE A%限制以 A开头外:LIKE A%2.更改表格 ALTER TABLE table_name ADD COLUMN column_name DATATYPE 说明:增加一个栏位(没有删除某个栏位的语法。)ALTER TABLE table_name ADD PRIMARY KEY(column_name)说明:更改表得的定义把某个栏位设为主键。ALT

20、ER TABLE table_name DROP PRIMARY KEY(column_name)说明:把主键的定义删除。3.group by 在 select 语句中可以使用 group by 子句将行划分成较小的组,然后,使用聚组函数返回每一个组的汇总信息,另外,可以使用 having子句限制返回的结果集。group by 子句可以将查询结果分组,并返回行的汇总信息 Oracle 按照 group by 子句中指定的表达式的值分组查询结果。在带有 group by 子句的查询语句中,在 select 列表中指定的列要么是 group by 子句中指定的列,要么包含聚组函数 select m

21、ax(sal),job emp group by job;(注意 max(sal),job 的 job 并非一定要出现,但有意义)查询语句的 select 和 group by,having 子句是聚组函数唯一出现的地方,在 where 子句中不能使用聚组函数。select deptno,sum(sal)from emp where sal1200 group by deptno having sum(sal)8500 order by deptno;当在 gropu by 子句中使用 having 子句时,查询结果中只返回满足 having条件的组。在一个 sql 语句中可以有 where子

22、句和 having子句。having 与 where 子句类似,均用于设置限定条件 where 子句的作用是在对查询结果进行分组前,将不符合 where条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使用 where条件显示特定的行。having 子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用 having 条件显示特定的组,也可以使用多个分组标准进行分组。查询每个部门的每种职位的雇员数 select deptno,job,count(*)from emp group by deptno,job;4.外连接与内连接 有时候,即使在连接的表中没有相应

23、的行,用户可能想从一张表中看数据,Oracle提供了外连接实现该功能。内连接是指连接查询只显示完全满足连接条件的记录,即等值连接,外连接的查询结果是内连接查询结果的扩展。外连接不仅返回满足连接条件的所有记录而且也返回了一个表中那些在另一个表中没有匹配行的记录。外连接的操作符是“+”。“+”号放在连接条件中信息不完全的那一边(即没有相应行的那一边)。运算符“+”影响 NULL行的建立。建一行或多行 NULL来匹配连接的表中信息完全的行。外连接运算符“+”只能出现在 where子句中表达式的一边。假如在多张表之间有多个连接条件,外连接运算符不能使用 or,in逻辑运算符与其它条件组合。假如 emp

24、 表中 deptno=10 的 ename为空值,dept 表中 deptno=20的 loc 为空值:1.select ename,dept.deptno,loc from emp,dept where emp.depno(+)=dept.deptno;如果在 dept.deptno 中有的数值在 emp.deptno 中没有值,则在做外连接时,结果中 ename会产生一个空值。(emp.deptno=10)2.select ename,dept.deptno,loc from emp,dept where emp.depno=dept.deptno(+);如果在 emp.deptno 中有

25、的数值在 dept.deptno 中没有值,则在做外连接时,结果中 loc会产生一个空值。(dept.deptno=20)5.自连接 自连接是指同一张表的不同行间的连接。该连接不受其他表的影响。用自连接可以比较同一张表中不同行的某一列的值。因为自连接查询仅涉及到某一张表与其自身的连接。所以在 from 子句中该表名出现两次,分别用两个不同的别名表示,两个别名当作两张不同的表进行处理,与其它的表连接一样,别名之间也使用一个或多个相关的列连接。为了区分同一张表的不同行的列,在名前永别名加以限制。select worker.ename,manager.ename manager from emp w

26、orker,emp manager where work.mgr=manager.empno;6.集合运算 基合运算符可以用于从多张表中选择数据。UNION运算 用于求两个结果集合的并集(两个结果集合的所有记录),并自动去掉重复行。select ename,sal from account where sal2000 union select ename,sal from research where sal2000 union select ename,sal from sales where sal2000;注:ename,sal 是必须一致的。UNION ALL运算 用于求两个结果集合的

27、并集(两个结果集中的所有记录),并且不去掉重复行。INTERSECT 运算 intersect 运算返回查询结果中相同的部分。各部门中有哪些相同的职位?select Job from account intersect select Job from research intersect select Job from sales;MINUS 运算 minus 返回两个结果集的差集。(在第一个结果集中存在的,而在第二个结果集中不存在的行。)有那些职位是财务部中有,而在销售部门中没有?select Job from account minus select Job from sales;创建数据

28、库 创建之前判断该数据库是否存在 if exists(select*from sysdatabases where name=databaseName)drop database databaseName go Create DATABASE database-name 删除数据库 drop database dbname 备份 sql server -创建 备份数据的 device USE master EXEC sp_addumpdevice disk,testBack,c:mssql7backupMyNwind_1.dat-开始 备份 BACKUP DATABASE pubs TO testBack 创建新表 create table tab

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1