Transact-SQL语言.ppt
《Transact-SQL语言.ppt》由会员分享,可在线阅读,更多相关《Transact-SQL语言.ppt(38页珍藏版)》请在三一办公上搜索。
1、第2章 Transact-SQL语言,Transact-SQL语言概述,第1节 单表查询问题:我们需要对数据进行哪些维护操作?如何对数据进行查询、统计?结构化查询语言(Structured Query Language)。这种语言的语法结构类似于英语,易学易用,书写随意。例如前面第一章讲过的例子,Transact-SQL语言的组成,1、数据定义语言DDL:用来定义和管理数据库中的对象。DDL主要的语句有:CREAT TABLE/*创建表*/ALTER TABLE/*修改表的属性*/DROP TABLE/*删除表*/2、数据操作语言DML:用来操作数据库中的对象和数据,是T-SQL中最常用的部分
2、。DML主要的语句有:SELECT/*从一个表或多个表中检索数据*/DELETE/*从表中删除数据*/INSERT/*向一个表中添加数据*/UPDATE/*修改表中已有的数据*/3、数据控制语言DCL:用来控制用户对数据库对象操作的权限。主要的命令有:GRANT/*授予权限*/REMOVE/*回收所授予的权限*/,操作数据,打开一个数据库 从当前数据库切换到要使用的数据库时必须使用USE语句,并使用GO语句作为结束行。使用SELECT子句SELECT子句主要用于检索数据,其基本格式为:SELECT 选择列表FROM 表的列表WHEAR 检索的条件【问题】从Student表中检索学号为00000
3、001的学生的姓名(StuName),要求显示学生的学号和姓名【练习】要求检索系部编号为01的班级信息,要求显示班级编号和班级名称,1、*的使用【例】显示学生表中所有信息【例】从学生表中检索学生所在班的班级编码2、使用DISTINCT【例】从学生表中检索学生所在班的班级编码,要求清除值相同的那些行3、使用TOP n PERCENT【例】从学生表中检索所有的信息,要求只显示前6行数据,4、修改检索结果中列的标题【问题】检索学生表中的学号、班级编码和姓名信息,并修改列标题方法有三:(1)将要显示的列标题用单引号括起来后接等号(),后接要检索的列名(2)将要显示的列标题用单引号括起来后,写在列名后面
4、,两者之间使用空格隔开(3)将要显示的列标题用单引号括起来后,写在列名后面,两者之间使用AS关键字【练习】使用其他两种方法,5、在查询结果中显示字符串【问题】检索课程表的信息,要求给出检索结果为:课程名称 课程编码SQL Server实用技术 课程编码为:001 课程编码为:课程编码为:思考:如何检索课程编码是001的课程名称?,6、使用WHERE限制检索的条件【例】检索课程编码为001的课程名称,要求只显示课程名称【练习】检索上“Linux操作系统”课程的主讲教师7、表达式作为SELECT语句中的列【例】要求检索课程表的课程信息,并显示报名人数和限制选课人数之比思考:如何将上面的检索结果按报
5、名人数和限制选课人数之比的升序排列?,8、使用ORDER BY子句重新排列检索结果【升序例子】【降序例子】也可以在ORDER BY子句中指定多个列【例】检索课程表的教师名、课程号、课程名,要求检索结果首先按教师名降序排列,教师名相同时,则按课程号的升序排列9、使用IN(NOT IN)关键字【例】检索课程编码为001004013的课程名称方法一:使用逻辑运算符OR 方法二:使用IN关键字(比使用逻辑运算符更为简单),问题,检索开设了“信息技术”类课程的教师名及其所开的课程名,要求先按教师名升序排列,教师名相同时,按课程名的降序排列,并将显示的列名改为中文。,操作数据(续),1、使用LIKE(NO
6、T LIKE)关键字通配符:%匹配包括0个或多个字符的字符串_匹配任何一个字符匹配任何在范围内的单个字符,例如:m-p匹配任何不在范围内的单个字符,例如:m-p、mnop通配符和字符串要括在单引号中【练习】解释下面的通配符表示的意义D%_a如果要查找通配符本身,需要将它们用方括号括起来【问题】检索以“制作”两字结尾的课程名(使用LIKE)【练习】检索姓名的第二个字为“丽”的学生信息,要求显示学生学号和姓名【问题】检索不姓“刘”的学生信息(使用NOT LIKE),2、使用IS NULL关键字用于检索列中没有赋值的行【问题】检索课程表中教师未定的课程名称和教师名,3.使用BETWEENAND(NO
7、T BETWEENAND)关键字用于检索在某一特定范围内的信息【问题】检索报名人数大于等于30并且小于等于40的课程信息,要求显示课程名称和报名人数(使用BETWEENAND)注意WHERE WillNum BETWEEN 30 AND 40包括30和40这两个值【问题】对上例使用NOT BETWEENAND也可以在WHERE字句中使用前面讲过的逻辑运算符检索某一范围内的信息【练习】检索报名人数比限制选课人数多一倍以及一倍以上的课程信息,要求显示课程名称、报名人数和限制选课人数之比,并按该比例的降续排列,4、使用UNION子句用于将两个或多个检索结果合并成一个结果【问题】从班级表中检索班级名,
8、从系部表中检索系部名,并将这两个检索结果合并起来使用时注意:(1)所有检索中的列数和列的顺序必须相同(2)所有检索中按顺序对应列的数据类型必须兼容(相同或者可以明确地转换)扩展(1)修改列标题(2)按新的列标题排序,5、使用COMPUTE子句用来计算总计或进行分组小计【问题】检索课程表中“信息技术”类的课程编码、课程名称、课程分类、报名人数,并计算平均报名人数说明 总计值或小计值作为附加新行出现在检索结果中。该子句用在WHERE子句之后从检索结果可以看到:检索结果中有两个结果集(1)包含选择的列的所有明细行(2)包含COMPUTE子句中所指定的聚合函数的合计使用聚合函数AVG()、MAX()、
9、MIN()、SUM()聚合函数也可以出现在SELECT子句中,例PAGE 39【例2.10】扩展(1)只检索课程分类为“信息技术”的课程信息(2)可以在检索结果中显示多个聚合函数合计,6、使用COMPUTEBY子句使用COMPUTEBY子句时必须使用ORDER BY对COMPUTEBY中的BY指定的列进行排序。【例】按类检索课程表中的课程编码、课程名称、课程分类、报名人数,并计算每类课程的平均报名人数从检索结果可以看到:检索结果中有多个组,每个组有两个结果集,这两个结果集中的内容同上,问题,问题 COMPUTE子句是在一个明细行的基础上增加一个总计或小计(有BY时),但如果只想统计每类课程的平
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Transact SQL 语言
![提示](https://www.31ppt.com/images/bang_tan.gif)
链接地址:https://www.31ppt.com/p-6522104.html