NySQL 存储过程基本语法及实例

--------------------基本语法--------------------

        一.创建存储过程
        create procedure sp_name()
        begin
.........
        end

        二.调用存储过程
        1. 基本语法:call sp_name ()
        注意:存储过程名称后面必须加括号,哪怕该存储过程没有参数传递

        三.删除存储过程
        1. 基本语法:
        drop procedure sp_name//

        2. 注意事项
                (1) 不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程

        四.其他常用命令

        1. show procedure status
        显示数据库中所有存储的存储过程基本信息,包括所属数据库,存储过程名称,创建时间等

        2. show create procedure sp_name
        显示某一个MySQL存储过程的详细信息


                -------------------- 数据类型及运算符--------------------
        一、基本数据类型:
        略

        二、变量:

        自定义变量:DECLARE a INT;
        SET a = 100;
        可用以下语句代替:DECLARE a INT DEFAULT 100;

        变量分为用户变量和系统变量,系统变量又分为会话和全局级变量

        用户变量:用户变量名一般以 @开头,滥用用户变量会导致程序难以理解及管理

        1、在mysql客户端使用用户变量
        mysql > SELECT 'Hello World' into @x ;
        mysql > SELECT @x ;

        mysql > SET @y='Goodbye Cruel World';
        mysql > select @y ;

        mysql > SET @z=1 + 2 + 3;
        mysql > select @z ;


        2、在存储过程中使用用户变量

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


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


        三、运算符:
        1. 算术运算符
                + 加 SET var1 = 2 + 2;
        4
                - 减 SET var2 = 3 - 2;
        1
                * 乘 SET var3 = 3 * 2;
        6
                / 除 SET var4 = 10 / 3;
        3.3333
        DIV 整除 SET var5 = 10 DIV 3;
        3
                % 取模 SET var6 = 10 % 3;
        1

        2. 比较运算符
                > 大于 1 > 2 False
                <小于 2 < 1 False
                <= 小于等于 2 <= 2 True
                >= 大于等于 3 >= 2 True
        BETWEEN 在两值之间 5 BETWEEN 1 AND 10 True
        NOT BETWEEN 不在两值之间 5 NOT BETWEEN 1 AND 10 False
        IN 在集合中 5 IN(1, 2, 3, 4) False
        NOT IN 不在集合中 5 NOT IN (1, 2, 3, 4)True
                = 等于 2 = 3 False
                <>, !=不等于 2 <>3 False
                <=>严格比较两个NULL值是否相等 NULL<=>NULL True
        LIKE 简单模式匹配 "Guy Harrison" LIKE "Guy%" True
        REGEXP 正则式匹配 "Guy Harrison" REGEXP "[Gg]reg" False
        IS NULL 为空 0 IS NULL False
        IS NOT NULL 不为空 0 IS NOT NULL True

        3. 逻辑运算符

        4. 位运算符
                | 或
                & 与
                << 左移位
                >> 右移位
        ~非(单目运算,按位取反)

        注释:

        mysql存储过程可使用两种风格的注释
        双横杠:--

                该风格一般用于单行注释
        c风格:/* 注释内容 */
        一般用于多行注释

                -------------------- 流程控制--------------------
        一、顺序结构
        二、分支结构
        if
        case 三、循环结构
                for循环
        while循环
                loop循环
        repeat until循环

        注:
        区块定义,常用
                begin
......
        end;
        也可以给区块起别名,如:
        lable:
        begin
...........
        end lable;
        可以用leave lable;
        跳出区块,执行区块以后的代码

        begin和end如同C语言中的 {
            和
        }。

        --------------------输入和输出--------------------

        mysql存储过程的参数用在存储过程的定义,共有三种参数类型, IN, OUT, INOUT
        Create procedure|function([[IN | OUT | INOUT ]参数名 数据类形...])

        IN 输入参数
        表示该参数的值必须在调用存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值

        OUT 输出参数
        该值可在存储过程内部被改变,并可返回

        INOUT 输入输出参数
        调用时指定,并且可被改变和返回

        IN参数例子:
        CREATE PROCEDURE sp_demo_in_parameter(IN p_in INT)
        BEGIN
        SELECT p_in;
        --查询输入参数
        SET p_in = 2;
        --修改
        select p_in;
        --查看修改后的值
        END;

        执行结果:
        mysql > set @p_in=1
        mysql > call sp_demo_in_parameter( @p_in)
        略
        mysql > select @p_in ;
        略
        以上可以看出,p_in虽然在存储过程中被修改,但并不影响 @p_id的值

                OUT参数例子
        创建:
        mysql > CREATE PROCEDURE sp_demo_out_parameter (OUT p_out INT)
        BEGIN
        SELECT p_out;/*查看输出参数*/
        SET p_out = 2;/*修改参数值*/
        SELECT p_out;/*看看有否变化*/
        END;

        执行结果:
        mysql > SET @p_out=1
        mysql > CALL sp_demo_out_parameter( @p_out)
        略

        mysql > SELECT @p_out ;
        略

        INOUT参数例子:
        mysql > CREATE PROCEDURE sp_demo_inout_parameter (INOUT p_inout INT)
        BEGIN
        SELECT p_inout;
        SET p_inout = 2;
        SELECT p_inout;
        END;

        执行结果:
        set @p_inout=1
        call sp_demo_inout_parameter (@p_inout) //
                略
        select @p_inout ;
        略


        附:函数库
        mysql存储过程基本函数包括:字符串类型,数值类型,日期类型

        一、字符串类
        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
        mysql > select substring(’abcd’, 0, 2);
        +———————–+
                | substring(’abcd’, 0, 2) |
                +———————–+
                |                       |
        +———————–+
                1 row in set(0.00sec)

        mysql > select substring(’abcd’, 1, 2);
        +———————–+
                | substring(’abcd’, 1, 2) |
                +———————–+
                | ab |
                +———————–+
                1 row in set(0.02sec)

        TRIM([[BOTH | LEADING | TRAILING] [padding]FROM]string2) //去除指定位置的指定字符
        UCASE(string2) //转换成大写
        RIGHT(string2, length) //取string2最后length个字符
        SPACE(count) //生成count个空格

        二、数值类型

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

        注:返回类型并非均为整数,如:

        (1) 默认变为整形值
        mysql > select round(1.23);
        +————-+
                | round(1.23) |
                +————-+
                | 1 |
                +————-+
                1 row in set(0.00sec)

        mysql > select round(1.56);
        +————-+
                | round(1.56) |
                +————-+
                | 2 |
                +————-+
                1 row in set(0.00sec)

        (2) 可以设定小数位数,返回浮点型数据

        mysql > select round(1.567, 2);
        +—————-+
                | round(1.567, 2) |
                +—————-+
                | 1.57 |
                +—————-+
                1 row in set(0.00sec)

        SIGN(number2) //返回符号,正负或0
        SQRT(number2) //开平方

        三、日期类型

        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) //分

        注:可用在INTERVAL中的类型:
        DAY, DAY_HOUR, DAY_MINUTE, DAY_SECOND, HOUR, HOUR_MINUTE, HOUR_SECOND, MINUTE, MINUTE_SECOND, MONTH, SECOND, YEAR
        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 NUMERIC(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';

你可能感兴趣的:(MySQL)