一:参数类型

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存储过程实践总结的更多相关文章

  1. MySQL存储过程实践

    对employees数据库建立存储过程 创建不含有输入输出变量的存储过程 DELIMITER // -- 设定语句结束分隔符 DROP PROCEDURE IF EXISTS GetEmployees ...

  2. Mysql存储过程给变量赋值的几种方法实践

    BEGIN DECLARE v_request_count INT; #申请次数 DECLARE v_plan_count INT; #安排次数 DECLARE v_learn_count INT; ...

  3. MySQL存储过程 CASE语句

    MySQL存储过程  CASE语句 除了IF语句,MySQL提供了一个替代的条件语句CASE. MySQL CASE语句使代码更加可读和高效. CASE语句有两种形式:简单的搜索CASE语句. 简单C ...

  4. MariaDB MariaDB、MySQL存储过程、游标基础应用举例说明

    MariaDB.MySQL存储过程.游标基础应用举例说明 by:授客 QQ:1033553122 测试环境: MariaDB-10.0.19-centos7-x86_64 实践操作: # 创建测试数据 ...

  5. MySql存储过程参考

    Mysql(9)---纪录一次实际开发过程中用到的复杂存储过程 为了尽可能的还原当时为什么需要用到存储过程,下面我写了个详细的文档,我们可以从需求文档出发来分析. 有关存储过程之前也写了两篇文章来做铺 ...

  6. MySQL存储过程(转)

    一.MySQL 创建存储过程 "pr_add" 是个简单的 MySQL 存储过程,这个存储过程有两个 int 类型的输入参数 "a"."b" ...

  7. MySql存储过程

    MySQL 存储过程 ```sql CREATE PROCEDURE myprocedure (IN para01 INTEGER) BEGIN DECLARE var01 CHAR(10); IF ...

  8. mysql存储过程和存储函数

    mysql存储过程和存储函数 存数函数代码示例: DROP PROCEDURE IF EXISTS calc_ci_day_suc_rate; delimiter // CREATE FUNCTION ...

  9. mysql存储过程编写-入门案例-遁地龙卷风

    (-1)写在前面 这篇文章只是简要的叙述了mysql存储过程编写的基本概念. 我使用的mysql版本是5.7.9-log. 参照<<深入浅出MySQL>>. (0) delim ...

随机推荐

  1. php给一张图片加上水印效果

    <?php /** * 功能:给一张图片加上水印效果 * $i 要加水印效果的图片 * $t 水印文字 * $size 文字大小 * $pos 水印的位置 * $color 文字的颜色 * $f ...

  2. 【转】linux之自建yum仓库

    原链接:http://www.live-in.org/archives/1410.html 平时使用yum方式安装更新软件,可以自建一个yum源,同步官方更新源,这样如果本地有机器要升级的话就可以直接 ...

  3. MySQL用户远程登陆

    默认情况下,root用户是不具备远程登录的权限. 1.切换mysql表,查看当前用户信息 select host,user from user where user = 'root' 2.给用户进行授 ...

  4. java.lang.NoClassDefFoundError: org/apache/commons/lang/StringUtils

    java.lang.NoClassDefFoundError: org/apache/commons/lang/StringUtils Caused by: java.lang.ClassNotFou ...

  5. Android provider authorities冲突

    在Android项目中的AndroidManifest中provider的authorities相当于一个系统级的全局变量它的值必须唯一,如果有两个应用的authorities相同会导致安装失败.

  6. 设置Ubuntu Mysql可以远程链接

    1:修改my.cnf配置文件 $sudo vim /etc/mysql/my.cnf 修改为: bind-address = 0.0.0.0 2:进行授权操作 mysql> grant all ...

  7. 猎豹上市(猎豹的广告收入中有70%来自BAT三家公司,总收入中有58%来自BAT)

    发表日期: 2014 年 5 月 9 日 From 网易专题 文/赵楠 村里那点儿事 猎豹移动上市之夜,我挺激动. 激动除了因为有好朋友在这家公司外,也因为猎豹移动在历史上的几次起承转合非常不易,在巨 ...

  8. Auto Install Workflow Manager 1.0

    Write-Host "- Begining Download Service Bus..." Start /W "c:\Program Files\Microsoft\ ...

  9. 10.1.5 Connection Character Sets and Collations

    10.1.5 Connection Character Sets and Collations Several character set and collation system variables ...

  10. BLOB二进制对象(blob.c/h)

    BLOB二进制对象(blob.c/h) 数据结构 struct blob_attr { uint32_t id_len; /** 高1位为extend标志,高7位存储id, * 低24位存储data的 ...