一:参数类型

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. 【译】神经网络与深度学习 Ch1-Section0

    用神经网络识别手写数字 人类的视觉系统是是大自然的奇迹.考虑下面手写数字序列: 大多数人能够轻易地是识别出是504192.在我们大脑的每个半球都有一个基础的皮质,这就是我们熟知的V1区,它包含了14亿 ...

  2. JavaScript语法学习笔记

    1.关于执行JavaScript代码的方法: 第一种方法是将JavaScript代码放到文档<head>标签中的<script>标签之间: <head>     & ...

  3. CentOS和Ubuntu的区别

    CentOS(Community ENTerprise Operating System)是Linux发行版之一,它是来自于Red Hat Enterprise Linux依照开放源代码规定释出的源代 ...

  4. meta property=og标签含义及作用

    不理解Meta Property=og标签是什么意思,以及对SEO的影响,看一下下面的介绍.Meta Property=og标签是什么呢?og是一种新的HTTP头部标记,即Open Graph Pro ...

  5. C语言函数指针变量和指针函数以及指针数组

    C语言中,一个函数总是占用一段连续的内存区,而函数名就是该函数所占内存区的首地址.我们可以把函数的这个首地址(或称入口地址)赋予一个指针变量,使该指针变量指向该函数.然后通过指针变量就可以找到并调用这 ...

  6. Android DrawerLayout 点击事情穿透

    今天使用DrawerLayout做网易4.4版本侧边栏发现点击DrawerLayout空白部分,下面部分content会获得点击事件.解决方法是在<!-- The navigation draw ...

  7. [POJ] 2453 An Easy Problem [位运算]

    An Easy Problem   Description As we known, data stored in the computers is in binary form. The probl ...

  8. [LA] 2031 Dance Dance Revolution

    Dance Dance Revolution Time limit: 3.000 seconds Mr. White, a fat man, now is crazy about a game nam ...

  9. js判断输入的是单字节还是双字节

    计算机上每一个字符.数字.汉字.字母等,都对应着unicode编码,unicode编码小于255的为单字节,大于255.小于65535的为双子节或三字节 查看一个字符对应的unicode编码 var ...

  10. HornetQ

    https://github.com/flsusp/http-queue https://github.com/sfr-network-service-platforms/hq-console htt ...