ImageVerifierCode 换一换
格式:DOCX , 页数:13 ,大小:21.11KB ,
资源ID:16556023      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/16556023.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(mssql触发器及存储过程的创建Word文件下载.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

mssql触发器及存储过程的创建Word文件下载.docx

1、- 查看数据库已有触发器use jxcSoftwaregoselect * from sysobjects where xtype=TR- 查看单个触发器exec sp_helptext 触发器名八修改触发器:alter trigger trigger_name九相关示例1在Orders表中建立触发器当向Orders表中插入一条订单记录时检查goods表的货品状态status是否为1(正在整理)是则不能 往Orders表加入该订单。create trigger orderinserton ordersafter insertas if (select status from goods,ins

2、ertedwhere goods.name=inserted.goodsname)=1beginprint the goods is being processedthe order cannot be committedrollback transaction -回滚避免加入end2在Orders表建立一个插入触发器在添加一条订单时减少Goods表相应的货品记录中的库存。create trigger orderinsert1update goods set storage=storage-inserted.quantityfrom goods,insertedwheregoods.name=

3、inserted.goodsname3在Goods表建立删除触发器实现Goods表和Orders表的级联删除。create trigger goodsdeleteon goodsafter deletedelete from orders where goodsname in(select name from deleted)4在Orders表建立一个更新触发器监视Orders表的订单日期(OrderDate)列使其不能手工修改.create trigger orderdateupdateafter updateif update(orderdate)raiserror( orderdate

4、cannot be modified,10,1)rollback transaction5在Orders表建立一个插入触发器保证向Orders表插入的货品名必须要在Goods表中一定存在。create trigger orderinsert3if (select count(*) from goods,inserted where goods.name=inserted.goodsname)=0 no entry in goods for this order6:Orders表建立一个插入触发器,保证向Orders表插入的货品信息要在Order表中添加alter trigger addOrde

5、ron Ordersfor insert insert into Orderselect inserted.Id, inserted.goodName,inserted.Number from insertedMySQL的存储过程存储过程语法存储过程如同一门程序设计语言,同样包含了数据类型、流程控制、输入和输出和它自己的函数库。-基本语法-一.创建存储过程create procedure sp_name().二.调用存储过程1.基本语法:call sp_name()注意:存储过程名称后面必须加括号,哪怕该存储过程没有参数传递三.删除存储过程drop procedure sp_name/2.注意

6、事项(1)不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程四.其他常用命令1.show procedure status显示数据库中所有存储的存储过程基本信息,包括所属数据库,存储过程名称,创建时间等2.show create procedure sp_name显示某一个mysql存储过程的详细信息-数据类型及运算符-一、基本数据类型:略二、变量:自定义变量:DECLARE a INT ; SET a=100; 可用以下语句代替:DECLARE a INT DEFAULT 100;变量分为用户变量和系统变量,系统变量又分为会话和全局级变量用户变量:用户变量名一般以开头,滥用用户变

7、量会导致程序难以理解及管理1、 在mysql客户端使用用户变量mysql SELECT Hello World into x; SELECT x; SET y=Goodbye Cruel World; select y; SET z=1+2+3; select z;2、 在存储过程中使用用户变量 CREATE PROCEDURE GreetWorld( ) SELECT CONCAT(greeting, World); SET greeting=Hello CALL GreetWorld( );3、 在存储过程间传递全局范围的用户变量 CREATE PROCEDURE p1( ) SET la

8、st_procedure=p1 CREATE PROCEDURE p2( ) SELECT CONCAT(Last procedure was ,last_procedure); CALL p1( ); CALL p2( );三、运算符:1.算术运算符+ 加 SET var1=2+2; 4- 减 SET var2=3-2; 1* 乘 SET var3=3*2; 6/ 除 SET var4=10/3; 3.3333DIV 整除 SET var5=10 DIV 3; 3% 取模 SET var6=10%3 ;2.比较运算符 大于 12 False 小于 21 False= 小于等于 2BETWEE

9、N 在两值之间 5 BETWEEN 1 AND 10 TrueNOT BETWEEN 不在两值之间 5 NOT BETWEEN 1 AND 10 FalseIN 在集合中 5 IN (1,2,3,4) FalseNOT IN 不在集合中 5 NOT IN (1,2,3,4) True= 等于 2=3 False, != 不等于 2 严格比较两个NULL值是否相等 NULLNULL TrueLIKE 简单模式匹配 Guy Harrison LIKE Guy% TrueREGEXP 正则式匹配 REGEXP Ggreg FalseIS NULL 为空 0 IS NULL FalseIS NOT N

10、ULL 不为空 0 IS NOT NULL True3.逻辑运算符4.位运算符| 或& 与 左移位 右移位 非(单目运算,按位取反)注释:mysql存储过程可使用两种风格的注释双横杠:-该风格一般用于单行注释c风格:/* 注释内容 */ 一般用于多行注释-流程控制-一、顺序结构二、分支结构ifcase三、循环结构for循环while循环loop循环repeat until循环注:区块定义,常用.end;也可以给区块起别名,如:lable:.end lable;可以用leave lable;跳出区块,执行区块以后的代码begin和end如同C语言中的 和 。-输入和输出-mysql存储过程的参数

11、用在存储过程的定义,共有三种参数类型,IN,OUT,INOUTCreate procedure|function(IN |OUT |INOUT 参数名 数据类形.)IN 输入参数表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值OUT 输出参数该值可在存储过程内部被改变,并可返回INOUT 输入输出参数调用时指定,并且可被改变和返回IN参数例子:CREATE PROCEDURE sp_demo_in_parameter(IN p_in INT)BEGINSELECT p_in; -查询输入参数SET p_in=2; -修改select p_in;-查看修改后

12、的值END;执行结果: set p_in=1 call sp_demo_in_parameter(p_in) select p_in;以上可以看出,p_in虽然在存储过程中被修改,但并不影响p_id的值OUT参数例子创建: CREATE PROCEDURE sp_demo_out_parameter(OUT p_out INT)SELECT p_out;/*查看输出参数*/SET p_out=2;/*修改参数值*/*看看有否变化*/ SET p_out=1 CALL sp_demo_out_parameter(p_out) SELECT p_out;INOUT参数例子: CREATE PROC

13、EDURE sp_demo_inout_parameter(INOUT p_inout INT)SELECT p_inout;SET p_inout=2;执行结果:set p_inout=1call sp_demo_inout_parameter(p_inout) /select p_inout;附:函数库mysql存储过程基本函数包括:字符串类型,数值类型,日期类型一、字符串类CHARSET(str) /返回字串字符集CONCAT (string2 , ) /连接字串INSTR (string ,substring ) /返回substring首次在string中出现的位置,不存在返回0LC

14、ASE (string2 ) /转换成小写LEFT (string2 ,length ) /从string2中的左边起取length个字符LENGTH (string ) /string长度LOAD_FILE (file_name ) /从文件读取内容LOCATE (substring , string ,start_position ) 同INSTR,但可指定开始位置LPAD (string2 ,length ,pad ) /重复用pad加在string开头,直到字串长度为lengthLTRIM (string2 ) /去除前端空格REPEAT (string2 ,count ) /重复co

15、unt次REPLACE (str ,search_str ,replace_str ) /在str中用replace_str替换search_strRPAD (string2 ,length ,pad) /在str后用pad补充,直到长度为lengthRTRIM (string2 ) /去除后端空格STRCMP (string1 ,string2 ) /逐字符比较两字串大小,SUBSTRING (str , position ,length ) /从str的position开始,取length个字符,mysql中处理字符串时,默认第一个字符下标为1,即参数position必须大于等于1 sel

16、ect substring(abcd,0,2);+| substring(abcd,0,2) | |1 row in set (0.00 sec) select substring(abcd,1,2);| substring(abcd,1,2) | ab |1 row in set (0.02 sec)TRIM(BOTH|LEADING|TRAILING padding FROMstring2) /去除指定位置的指定字符UCASE (string2 ) /转换成大写RIGHT(string2,length) /取string2最后length个字符SPACE(count) /生成count个空

17、格二、数值类型ABS (number2 ) /绝对值BIN (decimal_number ) /十进制转二进制CEILING (number2 ) /向上取整CONV(number2,from_base,to_base) /进制转换FLOOR (number2 ) /向下取整FORMAT (number,decimal_places ) /保留小数位数HEX (DecimalNumber ) /转十六进制HEX()中可传入字符串,则返回其ASC-11码,如HEX(DEF)返回4142143也可以传入十进制整数,返回其十六进制编码,如HEX(25)返回19LEAST (number , num

18、ber2 ,.) /求最小值MOD (numerator ,denominator ) /求余POWER (number ,power ) /求指数RAND(seed) /随机数ROUND (number ,decimals ) /四舍五入,decimals为小数位数返回类型并非均为整数,如:(1)默认变为整形值 select round(1.23);+-+| round(1.23) | 1 | select round(1.56);| round(1.56) | 2 |(2)可以设定小数位数,返回浮点型数据 select round(1.567,2);+-+| round(1.567,2)

19、| 1.57 |SIGN (number2 ) /返回符号,正负或0SQRT(number2) /开平方三、日期类型ADDTIME (date2 ,time_interval ) /将time_interval加到date2CONVERT_TZ (datetime2 ,fromTZ ,toTZ ) /转换时区CURRENT_DATE ( ) /当前日期CURRENT_TIME ( ) /当前时间CURRENT_TIMESTAMP ( ) /当前时间戳DATE (datetime ) /返回datetime的日期部分DATE_ADD (date2 , INTERVAL d_value d_typ

20、e ) /在date2中加上日期或时间DATE_FORMAT (datetime ,FormatCodes ) /使用formatcodes格式显示datetimeDATE_SUB (date2 , INTERVAL d_value d_type ) /在date2上减去一个时间DATEDIFF (date1 ,date2 ) /两个日期差DAY (date ) /返回日期的天DAYNAME (date ) /英文星期DAYOFWEEK (date ) /星期(1-7) ,1为星期天DAYOFYEAR (date ) /一年中的第几天EXTRACT (interval_name FROM da

21、te ) /从date中提取日期的指定部分MAKEDATE (year ,day ) /给出年及年中的第几天,生成日期串MAKETIME (hour ,minute ,second ) /生成时间串MONTHNAME (date ) /英文月份名NOW ( ) /当前时间SEC_TO_TIME (seconds ) /秒数转成时间STR_TO_DATE (string ,format ) /字串转成时间,以format格式显示TIMEDIFF (datetime1 ,datetime2 ) /两个时间差TIME_TO_SEC (time ) /时间转秒数WEEK (date_time ,sta

22、rt_of_week ) /第几周YEAR (datetime ) /年份DAYOFMONTH(datetime) /月的第几天HOUR(datetime) /小时LAST_DAY(date) /date的月的最后日期MICROSECOND(datetime) /微秒MONTH(datetime) /月MINUTE(datetime) /分可用在INTERVAL中的类型:DAY ,DAY_HOUR ,DAY_MINUTE ,DAY_SECOND ,HOUR ,HOUR_MINUTE ,HOUR_SECOND ,MINUTE ,MINUTE_SECOND,MONTH ,SECOND ,YEARD

23、ECLARE variable_name ,variable_name. datatype DEFAULT value; 其中,datatype为mysql的数据类型,如:INT, FLOAT, DATE, VARCHAR(length)例:DECLARE l_int INT unsigned default 4000000;DECLARE l_numeric NUMERIC(8,2) DEFAULT 9.95;DECLARE l_date DATE DEFAULT 1999-12-31DECLARE l_datetime DATETIME DEFAULT 1999-12-31 23:59:59DECLARE l_varchar VARCHAR(255) DEF

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1