Transact-SQL语言PPT演示课件_第1页
Transact-SQL语言PPT演示课件_第2页
Transact-SQL语言PPT演示课件_第3页
Transact-SQL语言PPT演示课件_第4页
Transact-SQL语言PPT演示课件_第5页
已阅读5页,还剩36页未读 继续免费阅读

下载本文档

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

文档简介

Transact-SQL语言,Transact-SQL语言概述,第1节单表查询问题:我们需要对数据进行哪些维护操作?如何对数据进行查询、统计?结构化查询语言(StructuredQueryLanguage)。这种语言的语法结构类似于英语,易学易用,书写随意。例如前面第一章讲过的例子,Transact-SQL语言的组成,1、数据定义语言DDL:用来定义和管理数据库中的对象。DDL主要的语句有:CREATTABLE/*创建表*/ALTERTABLE/*修改表的属性*/DROPTABLE/*删除表*/2、数据操作语言DML:用来操作数据库中的对象和数据,是T-SQL中最常用的部分。DML主要的语句有:SELECT/*从一个表或多个表中检索数据*/DELETE/*从表中删除数据*/INSERT/*向一个表中添加数据*/UPDATE/*修改表中已有的数据*/3、数据控制语言DCL:用来控制用户对数据库对象操作的权限。主要的命令有:GRANT/*授予权限*/REMOVE/*回收所授予的权限*/,操作数据,打开一个数据库使用SELECT子句SELECT子句主要用于检索数据,其基本格式为:SELECT选择列表FROM表的列表WHEAR检索的条件【例2-1】从Student表中检索学号为00000001的学生的姓名(StuName),要求显示学生的学号和姓名【练习1】要求检索系部编号为01的班级信息,要求显示班级编号和班级名称,1、*的使用例2.2【练习2】显示学生表中所有信息例2.3【练习3】从学生表中检索学生所在班的班级编码2、使用DISTINCT消除重复值例2.4【练习4】从学生表中检索学生所在班的班级编码,要求清除值相同的那些行3、使用TOPnPERCENT仅返回前N行:例2.5【练习5】从学生表中检索所有的信息,要求只显示前6行数据,4、修改检索结果中列的标题:例2.6【练习6】检索学生表中的学号、班级编码和姓名信息,并修改列标题方法有三:(1)将要显示的列标题用单引号括起来后接等号(),后接要检索的列名(2)将要显示的列标题用单引号括起来后,写在列名后面,两者之间使用空格隔开(3)将要显示的列标题用单引号括起来后,写在列名后面,两者之间使用AS关键字【练习】使用其他两种方法,5、在查询结果中显示字符串:例2.7【问题】检索课程表的信息,要求给出检索结果为:课程名称课程编码SQLServer实用技术课程编码为:001课程编码为:课程编码为:思考:如何检索课程编码是001的课程名称?(条件),6、使用WHERE限制检索的条件【练习7】检索课程编码为001的课程名称,要求只显示课程名称【练习8】检索上“Linux操作系统”课程的教师名7、表达式作为SELECT语句中的列【例】要求检索课程表的课程信息,并显示报名人数和限制选课人数之比算求函数:见右表回顾:报名人数和限制选课人数之比列名显示为:报名人数比例思考:如何将上面的检索结果按报名人数和限制选课人数之比的升序排列?,8、使用ORDERBY子句重新排列检索结果【升序例子2.11】【降序例子】也可以在ORDERBY子句中指定多个列【例2.12】检索课程表的教师名、课程号、课程名,要求检索结果首先按教师名降序排列,教师名相同时,则按课程号的升序排列9、使用IN(NOTIN)关键字【例】检索课程编码为001004013的课程名称方法一:使用逻辑运算符OR方法二:使用IN关键字(比使用逻辑运算符更为简单),练习,检索开设了“信息技术”类课程的教师名及其所开的课程名,要求先按教师名升序排列,教师名相同时,按课程名的降序排列,并将显示的列名改为中文。,综合练习,PART表(PNO(存储部件的数字),PNAME(名称),PRICE(价格)例1:从表PART里面把字段PRICE大于10的所有记录找出来,我们写出下面查询:SELECT*FROMPARTWHEREPRICE10;然后得到表:PNO|PNAME|PRICE-+-+-3|Bolt|154|Cam|25,PART:PNO|PNAME|PRICE-+-+-1|Screw|102|Nut|83|Bolt|154|Cam|25,例2:从表PART里面把字段PRICE等于0或小于等于15的并且PNAME为Bolt的所有记录找出来,结果:PNAME|PRICE-+-Bolt|15查询语句:SELECTPNAME,PRICEFROMPARTWHEREPNAME=BoltAND(PRICE=0ORPRICE=15);,例3:如果我们想知道如果我们买两个部件的话要多少钱,如下结果:PNAME|DOUBLE-+-Screw|20Nut|16Bolt|30查询语句为:SELECTPNAME,PRICE*2ASDOUBLEFROMPARTWHEREPRICE*250;,例4:查询PART里面所有部件的平均价格,结果:结果是:AVG_PRICE-14.5查询语句:SELECTAVG(PRICE)ASAVG_PRICEFROMPART;,操作数据(续),1、使用LIKE(NOTLIKE)关键字通配符:%匹配包括0个或多个字符的字符串_匹配任何一个字符匹配任何在范围内的单个字符,例如:m-p匹配任何不在范围内的单个字符,例如:m-p、mnop通配符和字符串要括在单引号中【练习】解释下面的通配符表示的意义D%_a如果要查找通配符本身,需要将它们用方括号括起来%D【例2.16】检索以“制作”两字结尾的课程名(使用LIKE)【练习】检索姓名的第二个字为“丽”的学生信息,要求显示学生学号和姓名【例2.18】检索不姓“刘”的学生信息(使用NOTLIKE),练习LIKE:表student(name),例1,查询name字段中包含有“明”字的。例2,查询name字段中以“李”字开头。例3,查询name字段中含有数字的。例4,查询name字段中含有小写字母的。例5,查询name字段中不含有数字的。,例1,select*fromstudentwherenamelike%明%例2,select*fromstudentwherenamelike李%例3,select*fromstudentwherenamelike%0-9%例4,select*fromstudentwherenamelike%a-z%例5,select*fromstudentwherenamelike%0-9%,2、使用ISNULL关键字用于检索列中没有赋值的行【例2.19】检索课程表中教师未定的课程名称和教师名,3、使用BETWEENAND(NOTBETWEENAND)关键字用于检索在某一特定范围内的信息【问题】检索报名人数大于等于30并且小于等于40的课程信息,要求显示课程名称和报名人数(使用BETWEENAND)注意WHEREWillNumBETWEEN30AND40包括30和40这两个值【问题】对上例使用NOTBETWEENAND也可以在WHERE字句中使用前面讲过的逻辑运算符检索某一范围内的信息【练习】检索报名人数比限制选课人数多一倍以及一倍以上的课程信息,要求显示课程名称、报名人数和限制选课人数之比,并按该比例的降续排列,4、使用COMPUTE子句用来计算总计或进行分组小计【问题】检索课程表中的课程编码、课程名称、课程分类、报名人数,并计算平均报名人数说明总计值或小计值作为附加新行出现在检索结果中。该子句用在WHERE子句之后从检索结果可以看到:检索结果中有两个结果集(1)包含选择的列的所有明细行(2)包含COMPUTE子句中所指定的聚合函数对筛选出的数据的合计使用聚合函数AVG()、MAX()、MIN()、SUM()聚合函数也可以出现在SELECT子句中,例PAGE32【例2.10】扩展(1)只检索课程分类为“信息技术”的课程信息(2)可以在检索结果中显示多个聚合函数的合计上面的例子是对显示的所有行进行总计,如何对信息进行分组小计呢?,5、使用COMPUTEBY子句【例】按类检索课程表中的课程编码、课程名称、课程分类、报名人数,并计算每类课程的平均报名人数从检索结果可以看到:检索结果中有多个组,每个组有两个结果集这两个结果集中的内容同上注意必须使用ORDERBY排序要分组的列【练习】检索周三上课的课程名称和教师名,并对符合条件的课程门数进行统计(提示:先完成前一部分,再使用聚合函数COUNT进行统计),问题,问题COMPUTE子句是在一个明细行的基础上增加一个总计或小计(有BY时),但如果只想统计每类课程的平均报名人数,该如何处理?,操作数据(续),1、使用GROUPBY子句【问题】按课程分类统计每类课程的平均报名人数与上面例子的区别:只有一个结果集说明(1)该子句用于将检索结果按照GROUPBY后指定的列进行分组,该子句写在WHERE子句后面(2)GROUPBY子句经常用于SELECT子句中包含有聚合函数的情况。此时,SELECT子句中选项列表中出现的列,只能是GROUPBY子句中的列或者包含在聚合函数中。,2、使用HAVING子句【问题】上面的例子中,如果只统计“信息技术”类课程的平均报名人数说明HAVING经常用在GROUPBY子句之后,用于限定结果集中的分组也可以使用WHERE子句可以看到,HAVING子句是对结果进行过滤,而WHERE是对原始记录进行过滤。注意HAVING子句中的列只能是GROUPBY子句中或者聚合函数中的列【问题】检索平均报名人数大于30人的课程类和每类平均报名人数【练习1】在课程表中,按所开设课程的系部编码分别统计总共报名人数【练习2】如果问:系部编码为01的系所开设的课程总共有多少学生报名,如何编程实现?,3、使用子查询在一个查询中包含另一个查询【问题】检索报名人数大于平均报名人数的课程编码、课程名称和报名人数STEP1:如何求平均报名人数STEP2:完成题目要求,4、使用UNION子句用于将两个或多个检索结果合并成一个结果【例2.31】从班级表中检索班级名,从系部表中检索系部名,并将这两个检索结果合并起来使用时注意:(1)所有检索中的列数和列的顺序必须相同(2)所有检索中按顺序对应列的数据类型必须兼容(相同或者可以明确地转换)扩展(1)修改列标题(2)按新的列标题排序,本节小结,本节小结SQL语言的组成SELECT语句的基本格式介绍了各种单表查询语句,多表查询,第2节多表查询如果问:“计算机应用工程系”下属的班级有哪些,应该查询哪些表格?这就是多表查询了。如果在多个表中进行查询,结果会怎样?USEXkGOSELECT*FROMDepartment,ClassGO结果集中,有54行(318),5列(23)。,问题:笛卡儿积运算过程?在笛卡儿积的结果中,分析存在的问题以及解决方法:(1)两列DepatNo的列值不同解决方法:加连接条件,成为相等连接【注】为了避免笛卡儿积,必须在WHERE子句中给出表格的连接条件:通常对于N个表格的检索,要有N-1个连接条件(2)出现了相同的列:解决方法:去掉相同的列,成为自然连接(3)加入“计算机应用工程系”的条件,成为带有选择条件的连接,【问题】检索“01电子商务”班的学生选修课程的情况,要求显示班级名称、学生学号、学生姓名、课程名称和上课时间分析班级名称、学生学号、学生姓名、课程名称、上课时间这些信息是分别在班级表、学生表、学生选课表和课程表中的,因此需要在多个表中进行查询。同时,必须在WHERE子句中给出连接条件。注意在引用的多表中,如果列名在多个表中同名,为了避免列名不明确,在SELECT子句中必须在列名前加上表的前缀,即“表名.列名”。【练习】检索“林斌”同学的选修课信息(课程编号、课程名称、上课时间),【练习1】查询每个系所开课程的门数,显示系代码、系名称、课程名称、开课门数【练习2】显示所有系的班级名称,要求计算各系班级数量,显示要求如下:,多表查询,1、非相等连接(比较连接)连接条件不是等号,而是比较运算符【例2-36】检索各班可以选择的不是本系开设的选修课程的信息(课本的例子),2、自连接自己和自己的连接【例2-37】检索课程类相同而系部编码不同的课程信息(意味着同一类的课程有多个系部开设),要求显示课程编码、课程名称、课程分类和系部编码使用别名【练习】检索学分大于等于2.5的课程信息,显示课程名称、学分、开设该课程的系部名称、报名人数,要求使用别名,外连接,上面介绍的都是内连接,以下是外连接:【例】检索学生的选课信息,要求显示学生学号、课程编码、课程名称1、左外连接(leftjoin)2、右外连接(rightjoin)3、全连接(fulljoin)4、交叉连接(crossjoin)(不带WHERE子句的是两个表的笛卡尔积)练习:显示各部门及其上级部门,使用EXISTS关键字,如果要解决这样的问题:【例2-42】检索已经报名选修了课程的学生的学号和姓名分析采用上面所学的方法能否解决?使用EXISTS关键字测试跟随的子查询的行是否存在要点一旦找到,立即停止找到则返回TRUE,否则返回FALSE,而不是返回一些行,使用NOTEXISTS【问题】查询没有选修001课程的学生学号和姓名。selectstuno,stunamefromstudentwherenotexists(select*fromstucouwherestuno=student.stunoandcouno=001),本节小结,多表查询非相等连接自连接使用别名外连接(左外连接、右外连接、全连接)和交叉连接使用EXISTS关键字,编辑用户表数据:添加,1、使用INSERT语句INSERT语句在简单的情况下有如下形式:INSERTINTO表(列名列表)values(数据值)。见:例2-43用INSERT和SELECT子查询添加一行或多行指定数据值见例:2-44INSERTtestTable1(元素1,元素2)SELECTColA,ColBFROMtesttable使用SELECTinto插入符合某种条件的多行见例:2-

温馨提示

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

评论

0/150

提交评论