zoukankan      html  css  js  c++  java
  • MySql 存储过程

        存储过程(Stored Procedure)是一段SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果带参数)来调用执行它。

    而普通SQL语句在执行的时候需要要先编译再执行。

    
    

    MySQL存储过程的创建
    CREATE PROCEDURE 过程名 ([过程参数[,...]])
    [特性 ...] 过程体
    mysql> DELIMITER //
    mysql> CREATE PROCEDURE proc1(OUT s int)
    -> BEGIN
    -> SELECT COUNT(*) INTO s FROM user;
    -> END
    -> //
    mysql> DELIMITER ;

    
    

    命令行下需要暂时修改MySQL的分隔符

    
    

    参数
    MySQL存储过程的参数用在存储过程的定义,共有三种参数类型,IN,OUT,INOUT,形式如:
    CREATE PROCEDURE([[IN |OUT |INOUT ] 参数名 数据类形...])
    IN 输入参数:表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值
    OUT 输出参数:该值可在存储过程内部被改变,并可返回
    INOUT 输入输出参数:调用时指定,并且可被改变和返回

    
    

    变量
    DECLARE variable_name [,variable_name...] datatype [DEFAULT value];
    其中,datatype为MySQL的数据类型,如:int, float, date, varchar(length)
    例如:
    DECLARE l_int int unsigned default 4000000;
    DECLARE l_numeric number(8,2) DEFAULT 9.95;
    DECLARE l_date date DEFAULT '1999-12-31';
    DECLARE l_datetime datetime DEFAULT '1999-12-31 23:59:59';
    DECLARE l_varchar varchar(255) DEFAULT 'This will not be padded';
    SET 变量名 = 表达式值 [,variable_name = expression ...]

    
    

    用户变量 变量名一般以@开头
    mysql > SELECT 'Hello World' into @x;
    mysql > SET @y='Goodbye Cruel World';

    
    

    mysql > CREATE PROCEDURE GreetWorld( ) SELECT CONCAT(@greeting,' World');
    mysql > SET @greeting='Hello';
    mysql > CALL GreetWorld( );

    
    

    在存储过程间传递全局范围的用户变量
    mysql> CREATE PROCEDURE p1() SET @last_procedure='p1';
    mysql> CREATE PROCEDURE p2() SELECT CONCAT('Last procedure was ',@last_proc);
    mysql> CALL p1( );
    mysql> CALL p2( );

    
    

    注释
    双模杠:-- 用于单行注释
    c风格: 一般用于多行注释

    
    

    MySQL存储过程的查询
    select name from mysql.proc where db=’数据库名’;

    
    


    SHOW CREATE PROCEDURE 数据库.存储过程名;
    ALTER PROCEDURE
    DROP PROCEDURE

    
    

    变量作用域是以begin end为界

    
    

    条件语句
    -> 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;

    
    

    case语句:
    -> 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;

    
    

    while ···· end while:
    -> begin
    -> declare var int;
    -> set var=0;
    -> while var<6 do
    -> insert into t values(var);
    -> set var=var+1;
    -> end while;
    -> end;

    
    

    repeat···· end repeat:
    -> begin
    -> declare v int;
    -> set v=0;
    -> repeat
    -> insert into t values(v);
    -> set v=v+1;
    -> until v>=5
    -> end repeat;
    -> end;

    
    

    loop ·····end loop:
    -> 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;

    
    

    lables 标号:
    标号可以用在begin repeat while 或者loop 语句前,语句标号只能在合法的语句前面使用。可以跳出循环,使运行指令达到复合语句的最后一步。

    
    

    ITERATE:
    通过引用复合语句的标号,来从新开始复合语句
    -> 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;

    
    

    附:

    
    

    //字符串函数
    CHARSET(str) //返回字串字符集
    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
    mysql> select substring('abcd',0,2);
    mysql> select substring('abcd',1,2);
    TRIM([[BOTH|LEADING|TRAILING] [padding] FROM]string2) //去除指定位置的指定字符
    UCASE (string2 ) //转换成大写
    RIGHT(string2,length) //取string2最后length个字符
    SPACE(count) //生成count个空格

    
    

    //日期函数
    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

    
    

    //数学函数
    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为小数位数]

     
    觉得不错,点个赞吧
  • 相关阅读:
    【转】VS2010中 C++创建DLL图解
    [转]error: 'retainCount' is unavailable: not available in automatic reference counting mode
    [转]关于NSAutoreleasePool' is unavailable: not available in automatic reference counting mode的解决方法
    【转】 Tomcat v7.0 Server at localhost was unable to start within 45
    【转】Server Tomcat v7.0 Server at localhost was unable to start within 45 seconds. If
    【转】SVN管理多个项目版本库
    【转】eclipse安装SVN插件的两种方法
    【转】MYSQL启用日志,和查看日志
    【转】Repository has not been enabled to accept revision propchanges
    【转】SVN库的迁移
  • 原文地址:https://www.cnblogs.com/luangeng/p/5448340.html
Copyright © 2011-2022 走看看