sql函数和存储.ppt

sql函数和存储.ppt

ID:48039835

大小:878.00 KB

页数:29页

时间:2020-01-14

sql函数和存储.ppt_第1页
sql函数和存储.ppt_第2页
sql函数和存储.ppt_第3页
sql函数和存储.ppt_第4页
sql函数和存储.ppt_第5页
资源描述:

《sql函数和存储.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第五章函数和存储过程1.表值函数和标量值函数2.系统存储过程3.用户自定义存储过程及执行标量函数标量函数返回在RETURNS子句中定义的单个数据值。函数返回类型是除text、next、image、cursor和timestamp外的任何数据类型。标量函数的创建语法格式如下:CREATEFUNCTION[schema_name.]function_name([{@parameter_name[AS][type_schema_name.]parameter_data_type[=default]}[,…n

2、]])RETURNSreturn_data_type[WITH[,…n]][AS]BEGIN标量函数function_bodyRETURNscalar_expressionEND参数描述:schema_name:用户定义函数所属的架构的名称。function_name:用户定义函数的名称。函数名称必须符合有关标识符的规则,并且在数据库中以及对其架构来说是唯一的。即使未指定参数,函数名称后也需要加上括号。@parameter_name:用户定义函数的参数,可声明一个或多

3、个参数。标量函数例:定义标量函数STUDENT_PASS(),统计学生考试是否合格的信息。代码如下:USEstudentGOCREATEFUNCTIONstudent_pass_info(@gradetinyint)RETURNSchar(8)BEGINDECLARE@infochar(8)IF@grade>=60SET@info='通过'ELSESET@info='不合格'RETURN@infoENDGO标量函数标量函数在查询分析器中输入以下代码,执行后结果.USEstudentGOSELECT课程

4、注册.学号,学生.姓名,课程.课程名,dbo.student_pass_info(成绩)AS是否通过FROM学生,课程注册,课程WHERE课程注册.课程号=课程.课程号AND课程注册.学号=学生.学号表值函数用户定义表值函数可分为内联表值函数和多语句表值函数。函数返回table数据类型。创建内联表值函数对于内联表值函数,没有函数主体,表是单个SELECT语句的结果集。语法格式如下:CREATEFUNCTION[schema_name.]function_name([{@parameter_name[A

5、S][type_schema_name.]parameter_data_type[=default]}[,…n]])RETURNSTABLE[WITH[,…n]][AS]RETURN[()select_stmt[]][;]表值函数参数描述:schema_name:用户定义函数所属的架构的名称。function_name:用户定义函数的名称。函数名称必须符合有关标识符的规则,并且在数据库中以及对其架构来说是唯一的。即使未指定参数,函数名称后也需要加上括号。@parame

6、ter_name:用户定义函数的参数。可声明一个或多个参数。[type_schema_name.]parameter_data_type:参数的数据类型及其所属的架构,后者为可选项。[=default]:参数的默认值。select_stmt:定义内联表值函数的返回值的单个SELECT语句表值函数例:定义内联表值函数TEACHER_COURSE(),函数根据参数返回教师开课的信息。代码如下:USEstudentGOCREATEFUNCTIONTEACHER_COURSE(@teacher_idchar(

7、12))RETURNSTABLEAS表值函数RETURN(SELECTDISTINCT教师.教师编号,教师.姓名,系部.系部名称,课程.课程名,专业.专业名称FROM教师,系部,课程,教师任课,专业WHERE教师.教师编号=@teacher_idAND教师.系部代码=系部.系部代码AND教师任课.教师编号=教师.教师编号and课程.课程号=教师任课.课程号AND教师任课.专业代码=专业.专业代码)GO表值函数表值函数在查询分析器中输入并执行以下代码USEstudentGOSELECT*FROMTEAC

8、HER_COURSE('100000000002')GO表值函数存储过程概述什么是存储过程一组预先编释好的代码,可以做为一个独立的数据库对象,也可以作为一个单元被用户的应用程序调用。存储过程在创建时就被编译和优化,调用一次以后,相关信息就保存在内存中,下次无须编译可以直接调用执行。·允许模块化编程,增强代码的重用性和共享性·使用存储过程可以加快程序的运行速度.·使用存储过程可以减少网络流量。·存储过程可以提高数据库的安全性。存储过程的优点1、系统存储过程

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。