mysql存储过程实践总结
一:参数类型
1.IN 只能读取参数并在函数内部更改有效,不能持久化到外部变量
2.OUT 不能读取参数,可以在函数内部修改并保存到外部变量
3.INOUT 既能读取又能持久化
二:基本格式
- mysql> DELIMITER //
- mysql> CREATE PROCEDURE proc1(OUT s int)
- -> BEGIN
- -> SELECT COUNT(*) INTO s FROM user;
- -> END
- -> //
- mysql> DELIMITER ;
1.变量定义 declare va int unsigned default 4000; declare va1 varchar(128) default 'hello,world';
2.变量赋值 set temp=12; 定义用户变量:set @va='variables';
3.注释: --note 当行注释 或者多行注释为类C风格
三、控制语句
1.if-then-else
- mysql > DELIMITER //
- mysql > CREATE PROCEDURE proc2(IN parameter int)
- -> begin
- -> declare var int;
- -> set var=parameter+1;
- -> if var=0 then
- -> insert into t values(17);
- -> end if;
- -> if parameter=0 then
- -> update t set s1=s1+1;
- -> else
- -> update t set s1=s1+2;
- -> end if;
- -> end;
- -> //
- mysql > DELIMITER ;
2.case -when
- mysql > DELIMITER //
- mysql > CREATE PROCEDURE proc3 (in parameter int)
- -> begin
- -> declare var int;
- -> set var=parameter+1;
- -> case var
- -> when 0 then
- -> insert into t values(17);
- -> when 1 then
- -> insert into t values(18);
- -> else
- -> insert into t values(19);
- -> end case;
- -> end;
- -> //
- mysql > DELIMITER ;
3.while --end while
- mysql > DELIMITER //
- mysql > CREATE PROCEDURE proc4()
- -> begin
- -> declare var int;
- -> set var=0;
- -> while var<6 do
- -> insert into t values(var);
- -> set var=var+1;
- -> end while;
- -> end;
- -> //
- mysql > DELIMITER ;
4.repeat -until --end repeat
- mysql > DELIMITER //
- mysql > CREATE PROCEDURE proc5 ()
- -> begin
- -> declare v int;
- -> set v=0;
- -> repeat
- -> insert into t values(v);
- -> set v=v+1;
- -> until v>=5
- -> end repeat;
- -> end;
- -> //
- mysql > DELIMITER ;
5.LABEL:loop leave LABEL end loop;
- mysql > DELIMITER //
- mysql > CREATE PROCEDURE proc6 ()
- -> begin
- -> declare v int;
- -> set v=0;
- -> LOOP_LABLE:loop
- -> insert into t values(v);
- -> set v=v+1;
- -> if v >=5 then
- -> leave LOOP_LABLE;
- -> end if;
- -> end loop;
- -> end;
- -> //
- mysql > DELIMITER ;
6.iterate
- mysql > DELIMITER //
- mysql > CREATE PROCEDURE proc10 ()
- -> begin
- -> declare v int;
- -> set v=0;
- -> LOOP_LABLE:loop
- -> if v=3 then
- -> set v=v+1;
- -> ITERATE LOOP_LABLE;
- -> end if;
- -> insert into t values(v);
- -> set v=v+1;
- -> if v>=5 then
- -> leave LOOP_LABLE;
- -> end if;
- -> end loop;
- -> end;
- -> //
- mysql > DELIMITER ;
四、基本函数
1.字符串类
CHARSET(str) //返回字串字符集
CONCAT (string2 [,... ]) //连接字串
INSTR (string ,substring ) //返回substring首次在string中出现的位置,不存在返回0
LCASE (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开头,直到字串长度为length
LTRIM (string2 ) //去除前端空格
REPEAT (string2 ,count ) //重复count次
REPLACE (str ,search_str ,replace_str ) //在str中用replace_str替换search_str
RPAD (string2 ,length ,pad) //在str后用pad补充,直到长度为length
RTRIM (string2 ) //去除后端空格
STRCMP (string1 ,string2 ) //逐字符比较两字串大小,
SUBSTRING (str , position [,length ]) //从str的position开始,取length个字符,
注:mysql中处理字符串时,默认第一个字符下标为1,即参数position必须大于等于1
2.数学类
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)返回19
LEAST (number , number2 [,..]) //求最小值
MOD (numerator ,denominator ) //求余
POWER (number ,power ) //求指数
RAND([seed]) //随机数
ROUND (number [,decimals ]) //四舍五入,decimals为小数位数]
3.日期时间类
ADDTIME (date2
,time_interval ) //将time_interval加到date2
CONVERT_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 ,FormatCodes ) //使用formatcodes格式显示datetime
DATE_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 ) //给出年及年中的第几天,生成日期串
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(datetime)
//月的第几天
HOUR(datetime)
//小时
LAST_DAY(date)
//date的月的最后日期
MICROSECOND(datetime)
//微秒
MONTH(datetime)
//月
MINUTE(datetime)
//分返回符号,正负或0
SQRT(number2) //开平方
mysql存储过程实践总结的更多相关文章
- MySQL存储过程实践
对employees数据库建立存储过程 创建不含有输入输出变量的存储过程 DELIMITER // -- 设定语句结束分隔符 DROP PROCEDURE IF EXISTS GetEmployees ...
- Mysql存储过程给变量赋值的几种方法实践
BEGIN DECLARE v_request_count INT; #申请次数 DECLARE v_plan_count INT; #安排次数 DECLARE v_learn_count INT; ...
- MySQL存储过程 CASE语句
MySQL存储过程 CASE语句 除了IF语句,MySQL提供了一个替代的条件语句CASE. MySQL CASE语句使代码更加可读和高效. CASE语句有两种形式:简单的搜索CASE语句. 简单C ...
- MariaDB MariaDB、MySQL存储过程、游标基础应用举例说明
MariaDB.MySQL存储过程.游标基础应用举例说明 by:授客 QQ:1033553122 测试环境: MariaDB-10.0.19-centos7-x86_64 实践操作: # 创建测试数据 ...
- MySql存储过程参考
Mysql(9)---纪录一次实际开发过程中用到的复杂存储过程 为了尽可能的还原当时为什么需要用到存储过程,下面我写了个详细的文档,我们可以从需求文档出发来分析. 有关存储过程之前也写了两篇文章来做铺 ...
- MySQL存储过程(转)
一.MySQL 创建存储过程 "pr_add" 是个简单的 MySQL 存储过程,这个存储过程有两个 int 类型的输入参数 "a"."b" ...
- MySql存储过程
MySQL 存储过程 ```sql CREATE PROCEDURE myprocedure (IN para01 INTEGER) BEGIN DECLARE var01 CHAR(10); IF ...
- mysql存储过程和存储函数
mysql存储过程和存储函数 存数函数代码示例: DROP PROCEDURE IF EXISTS calc_ci_day_suc_rate; delimiter // CREATE FUNCTION ...
- mysql存储过程编写-入门案例-遁地龙卷风
(-1)写在前面 这篇文章只是简要的叙述了mysql存储过程编写的基本概念. 我使用的mysql版本是5.7.9-log. 参照<<深入浅出MySQL>>. (0) delim ...
随机推荐
- log4j配置文件及nutch中的日志配置
使用slf4j作为日志系统时,由于slf4j只是一个接口,它需要一个具体实现来执行. 具体参考http://blog.csdn.net/jediael_lu/article/details/43854 ...
- MAC中通过gem命令安装compass
在MAC中通过gem命令安装compass时会出异常,原因是compass版本更新了,一些运行时所用到的依赖软件的版本没能得到更新,故而出现错误.例如,用以下命令安装compass: $ gem in ...
- django-filter 使用Filter来筛选你的数据
django-filter Django-filter is a generic, reusable application to alleviate writing some of the more ...
- Sherlock and GCD
1 import fractions, functools, sys if __name__ == '__main__': T = int(sys.stdin.readline()) for _ in ...
- Nasty Hacks <入门练手题>
Nasty Hacks Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- vc获取时间戳
CTime cTime = CTime::GetCurrentTime(); CString msg; msg.Format("%u",cTime .GetTime()); Afx ...
- DDP和DDU什么区别
DU/DDP 就是A发货给国外B,B只要呆在家里看电视,货会自动送上门,当中的所有运输清关等事情都是由A来负责(A可以委托货代来负责),区别就是DDU是不包括税金的,也就是货值的百分之多少,税金会在B ...
- 统计维护<第四篇>
SQL Server允许用户手工地控制单独数据库中的统计维护.SQL Server的4个主要的控制紫铜统计的维护的配置如下: 在无索引的列上新建统计(自动创建统计): 更新现有统计(自动更新统计): ...
- Microsoft Certification List
Exam Title Files 70-178 Microsoft Project 2010, Managing Projects 16 70-243 Administering and Deploy ...
- 转:PHP变量作用域(花括号、global、闭包)
花括号 很多语言都以花括号作为作用域界限,PHP中只有函数的花括号才构成新的作用域. 01 <?php 02 if (True) { 03 $a = 'var a'; 04 } 05 ...