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