实验四 T-SQL编程

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验四T-SQL编程
1、目的与要求
(1)进一步巩固第2章至第4章所学内容。

(2)掌握用户自定义数据类型。

(3)掌握变量的分类及其使用方法。

(4)掌握各种运算符的使用。

(5)掌握各种控制语句的使用。

(6)掌握系统函数及用户自定义函数的使用。

2、实验准备。

(1)了解T-SQL支持的各种基本数据类型。

(2)了解自定义数据类型使用的一般步骤。

(3)了解T-SQL各种运算符、控制语句的功能及其使用方法。

(4)了解系统函数的调用方法。

(5)了解用户自定义函数使用的一般步骤。

3、实验内容
(1)自定义数据类型的使用。

①对于实验2中给出的数据库结构,再自定义一数据类型ID_type,用户描述员工编号。

在“查询分析器”窗口中输入如下程序并执行。

执行上面代码,但是出现这样的错误,不知道是不是之前就存在了。

②在YGGL数据库中创建表Employees3表,表结构与Employees表类似,知识EmployeeID 列使用的数据类型为用户自定义数据类型ID_type。

(2)变量的使用。

①对于实验2给出的数据库表结构,创建一个名为female的用户变量,并在SELECT语句中使用该局部变量查找表中所有女员工的编号、姓名。

②定义一个变量,用户获取员工号码为102201的员工的电话号码。

执行完上面语句后可以得到变量phone的值,如上面截图中结果。

【思考与练习】
定义一个变量,用于描述YGGL数据库的Salary表中000001号员工的实际收入,然后查询该变量。

首先declare定义变量RealInCome,然后利用SELECT语句查询EmployeeID=000001的员工的实际收入赋值给RealInCome,最后利用SELECT查询RealInCome变量的值。

(3)运算符的使用。

①使用算数运算符“-”,查询员工的实际收入。

② 使用比较运算符“>”,查询Employees表中工作时间大于5年的员工信息。

执行上面代码,在结果栏中显示工作时间大于5年的员工信息。

【思考与练习】
熟悉各种常用运算符的功能和用法,如LIKE、BETWEEN等。

(4)流程控制语句。

①判断Employees表中是否存在编号为111006的员工,若存在,则显示该员工的信息;若不存在,则显示“查无此人”。

执行上面代码,在结果栏中显示是否存在员工编号为111006的员工。

【思考与练习】
判断姓名为“王林”的雇员的实际收入是否高于3000元,如果是,则显示其收入,否则显示“收入不高于3000”。

②假设变量X的初始值为0,每次增加1,直至X变为5.
【思考与练习】
使用循环输出一个用“*”组成的三角形。

在这里将用到常用的字符长处理函数,replicate(<字符表达式>,<次数>)和space(<次数>)。

Replicate的功能是以指定次数重复字符表达式。

Space的功能是返回指定个数重复的空格组成的字符串。

③ 使用CASE语句对Employees表按部门进行分类。

【思考与练习】
使用IF语句实现上面的功能。

(使用if语句将Employees表按照部门进行分类。


我首先在“查询分析器”中用T-SQL语句创建了用户自定义函数useif。

并且返回@s(@s 是当DepartmentID为相应编号是对应的DepartmentName)。

然后重新建一个“查询分析器”,在其中使用函数useif,参数就是DepartmentID。

执行上面新建的用户自定义函数,然后在左侧对象资源管理器中的YGGL数据库的“可编程”→“函数”→“标量函数”里面可以可看到刚刚创建的函数。

然后在新的“查询分析器”中调用上面创建的函数useif。

虽然会出现红色波浪下划线,并且提示“找不到列"dbo" 或用户定义的函数或聚合"dbo.xxx",或者名称不明确。

”但是还是执行成功,并且输出结果。

(5)自定义函数的使用。

①定义一个函数实现如下功能:对于给定的DepartmentID值,查询该值在Departments表中是否存在,若存在则返回0,否则返回-1。

新建一个查询,在“查询分析器”窗口中输入如下程序并执行。

② 写一段T-SQL程序调用上述函数。

当向Employees表中插入一行记录时,首先调用函数CHECK_ID检索记录的DepartmentID值在表Departments的DepartmentID字段中是否存在对应值,若存在,则该记录插入Employees表。

执行上面T-SQL语句,在下方显示1行受影响,说明已经向Employees表中插入数据。

【思考与练习】
自定义一个函数,计算一个数的阶乘。

首先新建一个查询,在“查询分析器”窗口中输入下面程序,并且执行,生成函数factorial(@num int)。

并将计算结果作为函数返回值。

然后重新建一个查询,在“查询分析器”窗口中进行调用函数factorial,并输出计算结
果。

在结果栏中显示计算结果为“6”。

(因为这里@num=3作为函数factorial的参数进行计算的)
(6)系统内置函数的使用。

① 求一个数的绝对值。

【思考与练习】
A、使用RAND()函数产生一个0~1的随机数。

第一种,不指定RAND()函数内的种子值,使其随机产生。

返回值为float类型。

第二种,指定种子值。

注:两者区别,若没有指定种子值,那么将随机分配种子值,每次执行结果不一样。

对于指定了种子值,返回的结果始终相同。

对于上面指定种子值5,则每次产生的结果都是相同的。

(上面截图显示)
B、使用SQUARE()函数获得一个数的平方。

C、使用SQRT()函数返回一个数的平方根。

②求财务部雇员的总人数。

【思考与练习】
A、求财务部收入最高的雇员姓名。

B、查询员工收入的平均数。

C、聚合函数如何与GROUP BY函数一起使用。

举个例子,利用GROUP BY查询不同部门人数
③聚合函数ASCII函数返回字符表达式最左端字符的ASCII值。

【思考与练习】
A、使用CHAR()函数将ASCII码代表的字符组成字符串。

因为此处char()函数是一个参数的,因此输出字符串做了这样的处理。

B、使用LEFT()函数返回从字符串’abcdef’左边开始的3个字符。

④获得当前时间和日期。

查询YGGL数据库中员工号为000001的员工的出生年份。

【思考与练习】
A、使用DAY()函数返回指定日期的天数。

B、列举出其他的时间日期函数。

DATEPART函数。

DATEADD函数获取下一时间之前或者之后的时间日期。

DATEDIFF函数,返回跨两个指定日期的日期和时间边界数。

DATENAME函数,返回代表指定日期的指定日期部分的字符串。

DATENAME函数,返回时间为当天的第几小时,第几分钟,第几秒。

C、使用其他类型的系统内置函数。

使用系统内置函数返回服务器端计算机的主机号和名称。

使用系统内置函数返回数据库的编号和名称。

4、实验总结
通过本次实验知道了SQL中的常用日期时间函数,并且也将这些函数做了总结,就像上面的截图中显示的那样。

同样也了解了系统内置函数的使用方法。

同样通过这次式样,在操作方面自己有很大的提升,将遇到的问题反复的进行操作。

通过子查询或者连接查询的方式了解了函数的作用,同时也了解了子查询和连接查询在不同的情况下的优缺点,以及查询效率之间的问题。

对于自定义函数的使用也了解掌握了不少。

总是通过这次实验我的收获很多。

相关文档
最新文档