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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

MySQL 创建存储过程Word下载.docx

1、习惯上,对于是“in” 的参数,我们都不会显式指定。1. MySQL 存储过程名字后面的“()”是必须的,即使没有一个参数,也需要“()”2. MySQL 存储过程参数,不能在参数名称前加“”,如:“a int”。下面的创建存储过程语法在 MySQL 中是错误的(在 SQL Server 中是正确的)。 MySQL 存储过程中的变量,不需要在变量名字前加“”,虽然 MySQL 客户端用户变量要加个“”。 a int,- 错误 b int - 正确3. MySQL 存储过程的参数不能指定默认值。4. MySQL 存储过程不需要在 procedure body 前面加 “as”。而 SQL Ser

2、ver 存储过程必须加 “as” 关键字。as - 错误,MySQL 不需要 “as” mysql statement .;5. 如果 MySQL 存储过程中包含多条 MySQL 语句,则需要 begin end 关键字。 mysql statement 1 .; mysql statement 2 .;6. MySQL 存储过程中的每条语句的末尾,都要加上分号 “;” .7. MySQL 存储过程中的注释。 这是个 多行 MySQL 注释。 - 这是单行 MySQL 注释 (注意- 后至少要有一个空格) if a is null then 这也是个单行 MySQL 注释8. 不能在 MySQ

3、L 存储过程中使用 “return” 关键字。9. 调用 MySQL 存储过程时候,需要在过程名字后面加“()”,即使没有一个参数,也需要“()”call pr_no_param();10. 因为 MySQL 存储过程参数没有默认值,所以在调用 MySQL 存储过程时候,不能省略参数。可以用 null 来替代。call pr_add(10, null);mysql 5.0存储过程学习总结一.创建存储过程1.基本语法:create procedure sp_name()end2.参数传递二.调用存储过程call sp_name()注意:存储过程名称后面必须加括号,哪怕该存储过程没有参数传递三.删

4、除存储过程drop procedure sp_name/2.注意事项(1)不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程四.区块,条件,循环1.区块定义,常用也可以给区块起别名,如:lable:.end lable;可以用leave lable;跳出区块,执行区块以后的代码2.条件语句if 条件 thenstatementelseend if;3.循环语句(1).while循环label: WHILE expression DOstatementsEND WHILE label ;(2).loop循环 LOOPEND LOOP label;(3).repeat until循环

5、REPEATUNTIL expressionEND REPEAT label ;五.其他常用命令1.show procedure status显示数据库中 所有存储的存储过程基本信息,包括所属数据库,存储过程名称,创建时间等2.show create procedure sp_name显示某一个存储过程的详细信息mysql存储过程中要用到的运算符mysql存储过程学习总结操作符算术运算符+ 加 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

6、3; 3% 取模 SET var6=10%3 ;比较运算符 大于 12 False 小于 21 False= 小于等于 2BETWEEN 在两值之间 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值是否相等 NULL select substring(abcd,0,2);+| substring(abcd,0,

7、2) | |1 row in set (0.00 sec) select substring(abcd,1,2);| substring(abcd,1,2) | ab1 row in set (0.02 sec)TRIM(BOTH|LEADING|TRAILING padding FROMstring2) /去除指定位置的指定字符UCASE (string2 ) /转换成大写RIGHT(string2,length) /取string2最后length个字符SPACE(count) /生成count个空格二.数学类ABS (number2 ) /绝对值BIN (decimal_number )

8、 /十进制转二进制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 , number2 ,.) /求最小值MOD (numerator ,denominator ) /求余

9、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) | 1.57 |SIGN (number2 ) /返回符号,正负或0SQRT(number2)

10、 /开平方三.日期时间类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_type ) /在date2中加上日期或时间DATE_FORMAT (datetime ,Form

11、atCodes ) /使用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 date ) /从date中提取日期的指定部分MAKEDATE (year ,day ) /给出

12、年及年中的第几天,生成日期串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 ,start_of_week ) /第几周YEAR (datetime ) /年份DAYOFMONTH(dateti

13、me) /月的第几天HOUR(datetime) /小时LAST_DAY(date) /date的月的最后日期MICROSECOND(datetime) /微秒MONTH(datetime) /月MINUTE(datetime) /分附:可用在INTERVAL中的类型DAY ,DAY_HOUR ,DAY_MINUTE ,DAY_SECOND ,HOUR ,HOUR_MINUTE ,HOUR_SECONDMySQL存储过程例子,包含事务,参数,嵌套调用,游标,循环等view plaincopy to clipboardprint?drop procedure if exists pro_rep_

14、shadow_rs; delimiter |- rep_shadow_rs- 用来处理信息的增加,更新和删除- 每次只更新上次以来没有做过的数据- 根据不同的标志位- 需要一个输出的参数,- 如果返回为0,则调用失败,事务回滚- 如果返回为1,调用成功,事务提交- 测试方法- call pro_rep_shadow_rs(rtn);- select rtn;create procedure pro_rep_shadow_rs(out rtn int)begin - 声明变量,所有的声明必须在非声明的语句前面 declare iLast_rep_sync_id int default -1; d

15、eclare iMax_rep_sync_id int default -1; - 如果出现异常,或自动处理并rollback,但不再通知调用方了 - 如果希望应用获得异常,需要将下面这一句,以及启动事务和提交事务的语句全部去掉 declare exit handler for sqlexception rollback; - 查找上一次的 select eid into iLast_rep_sync_id from rep_de_proc_log wheretbl=rep_shadow_rs; - 如果不存在,则增加一行 if iLast_rep_sync_id=-1 then insert

16、 into rep_de_proc_log(rid,eid,tbl) values(0,0,); set iLast_rep_sync_id = 0; - 下一个数字 set iLast_rep_sync_id=iLast_rep_sync_id+1; - 设置默认的返回值为0:失败 set rtn=0; - 启动事务 start transaction; - 查找最大编号 select max(rep_sync_id) into iMax_rep_sync_id from rep_shadow_rs; - 有新数据 if iMax_rep_sync_id=iLast_rep_sync_id

17、then - 调用 call pro_rep_shadow_rs_do(iLast_rep_sync_id,iMax_rep_sync_id); - 更新日志 update rep_de_proc_log setrid=iLast_rep_sync_id,eid=iMax_rep_sync_id where tbl= - 运行没有异常,提交事务 commit; - 设置返回值为1 set rtn=1;delimiter ;drop procedure if exists pro_rep_shadow_rs_do;- 处理指定编号范围内的数据- 需要输入2个参数- last_rep_sync_i

18、d 是编号的最小值- max_rep_sync_id 是编号的最大值- 无返回值create procedure pro_rep_shadow_rs_do(last_rep_sync_id int, max_rep_sync_idint) declare iRep_operationtype varchar(1); declare iRep_status varchar(1); declare iRep_Sync_id int; declare iId int; - 这个用于处理游标到达最后一行的情况 declare stop int default 0; - 声明游标 declare cur cursor for selectid,Rep

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

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