欢迎来到天天文库
浏览记录
ID:59439393
大小:1.25 MB
页数:43页
时间:2020-09-18
《自定义数据类型函数视图ppt课件.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、自定义数据类型、函数用户自定义数据类型用户自定义数据类型:在SQLServer系统数据类型的基础上创建的可使相似的数据类型标准化,避免重复设置。Model数据库中创建的用户自定义数据类型:出现在所有以后新建的数据库中。用户自定义数据类型语句:创建自定义数据类型Sp_addtypeSp_addtypeTel,'varchar(20)','notnull'删除自定义数据类型Sp_droptypesp_droptypeTel管理器:创建自定义数据类型删除自定义数据类型使用自定义数据类型新建表,设置某字段为自定义数据类型用户自定义函数(function)用户自定义函数是由一个
2、或多个Transact-SQL语句组成的子程序。一般是为了方便重用而创建的。有输入参数和返回值,但没有输出参数。使用createfunction语句创建,使用alterfunction语句修改,使用dropfunction语句除去。Transact-SQL语言编程常量和变量常量:字符串常量:包含在单引号内,由字母数字字符以及特殊字符(如!、@、#)组成。数值常量:二进制、bit、int、float等类型的常量。日期常量:使用特定格式的字符日期值表示,并被单引号括起来。注:引用数值常量不用单引号,引用日期、字符串常量时需要加单引号‘1998/01/31’变量变量:在程序
3、运行过程中其值是变化的量局部变量(以@开头;使用DECLARE语句声明)【问题】DECLARE@var1int,@var2moneySELECT@var1=50,@var2=$29.95SET@j=50全局变量(也称配置函数,是系统定义的变量,以@@开头;用户只能使用)例如:version@@DECLARE声明局部变量SELECT或SET局部变量附值练习2问题:编写程序计算已知的两个整数之和DECLARE@iint,@jint,@sumint--定义三个局部变量SET@i=50--给变量@i赋值50SET@j=60--给变量@j赋值60SELECT@sum=@i+@j
4、--将@i和@j的和赋值给变量@sumPRINT@sum--显示@sum变量的内容运算符算术运算符(+、-、*、/、%)一元运算符(+、-、~)比较运算符(=、>、<、>=、<=、<>、!=、!<、!>)逻辑运算符(NOT、OR、AND、IN、LIKE、BETWEEN、EXISTS)字符串连接运算符(+)赋值运算符(=)位运算符(&、
5、、^、~)求余按位非按位异或流控语句【问题】如何用SQL语句编程实现:求1+2+3+4+…+100=?编程思想:代码:分析:WHILE、BEGIN…END、IF…ELSE…、GOTO的使用用法其他流控语句的使用用法BRAEK:在循环语句
6、中,用于退出本层循环CONTINUE:在循环语句中,结束本次循环,重新转到下一次循环条件的判断Declare@iint,@sumintSelect@i=0,@sum=0While@i<=100beginselect@sum=@sum+@iselect@i=@i+1endselect@sumPrint也可以,仅显示位置不同(1)创建标量用户自定义函数返回一个,如int、char、decimal等,但禁止使用text、ntext、image、cursor和timestamp作为返回的参数。该函数的函数体被封装在以BEGIN语句开始,END语句结束的范围内。用户自定义函数的
7、实现使用CREATEFUNCTION语句编写自已的函数用户自定义函数可用传递一个或多个参数简单的数值其语法格式如下:CREATEFUNCTION[owner_name].function_name(@parameter_namescalar_parameter_data_type)RETURNSscalar_return_data_type[AS]BEGINFUNCTION_bodyRETURNscalar_expressionEND【例】创建一个自定义函数,返回特定课程的平均成绩。CREATEFUNCTIONAvgGrade_SC(@CourseIDVarchar(
8、20))RETURNSFLOATASBEGINDECLARE@AVG_GradeFLOATSET@AVG_Grade=(SELECTAVG(Grade)FROMSCWHERECourseID=@CourseID)RETURN@AVG_GradeEND函数调用selectdbo.AvgGrade_SC('30106')思考:创建一个自定义函数,返回指定教师的选课学生的数目。(假定一个教师教授一门课)createfunctionTeaChNum(@TeaNamevarchar(20))returnsintasbegindeclare@CouIDvarch
此文档下载收益归作者所有