一:参数类型

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. head直接复制的

    <script type="application/x-javascript"> addEventListener("load", function ...

  2. 在fedora 20下使用ssh server

    在红帽和centos下,一般安装完后会自带ssh,然后可以通过/etc/init.d/sshd start的方式运行,但是在Fedora 20下,系统改用了另外一套服务开启机制. 首先安装ssh se ...

  3. 蓝牙芯片NRF51822入门学习1:时间管理

    前言 之前辞职找工作的时候发现,很多公司希望招聘蓝牙技术方面的人才,所以干脆丢开LWIP静下心来学习蓝牙技术.原本以为一两星期能基本学会的,谁知道所选的蓝牙芯片nrf51822是个坑货,坑了我一个月. ...

  4. 24C01的IIC 讀寫的c51程式

    /*------------------------------------------------------------------------------ 為了安全起見,程式中很多NOP是冗餘的 ...

  5. Driver Signing changes in Windows 10

    Driver Signing changes in Windows 10 RATE THIS 1 Apr 2015 1:28 PM  39 Beginning with the release of ...

  6. key转成pvf

    https://www.godaddy.com/help/converting-an-exported-pfx-code-signing-file-to-pvk-and-spc-files-using ...

  7. SQL Server 性能优化之——重复索引

    原文 http://www.cnblogs.com/BoyceYang/archive/2013/06/16/3139006.html 阅读导航 1. 概述 2. 什么是重复索引 3. 查找重复索引 ...

  8. Android开源中国客户端学习 (自定义View)左右滑动控件ScrollLayout

    左右滑动的控件我们使用的也是非常多了,但是基本上都是使用的viewpager 等 android基础的控件,那么我们有么有考虑过查看他的源码进行定制呢?当然,如果你自我感觉非常好的话可以自己定制一个, ...

  9. STL中istream_iterator和ostream_iterator的基本用法

    标准程序库定义有供输入及输出用的iostream iterator类,称为istream_iterator和ostream_iterator,分别支持单一型别的元素读取和写入.使用这两个iterato ...

  10. HDU 5424 Rikka with Graph II

    题目大意: 在 N 个点 N 条边组成的图中判断是否存在汉密尔顿路径. 思路:忽略重边与自回路,先判断是否连通,否则输出"NO",DFS搜索是否存在汉密尔顿路径. #include ...