博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第二百八十七节,MySQL数据库-条件语句、循环语句、动态执行SQL语句
阅读量:4670 次
发布时间:2019-06-09

本文共 2397 字,大约阅读时间需要 7 分钟。

MySQL数据库-条件语句、循环语句、动态执行SQL语句

 

1、if条件语句

delimiter \\CREATE PROCEDURE proc_if ()BEGIN        declare i int default 0;    if i = 1 THEN        SELECT 1;    ELSEIF i = 2 THEN        SELECT 2;    ELSE        SELECT 7;    END IF;END\\delimiter ;

 

 

 

2、循环语句

while循环

delimiter \\CREATE PROCEDURE proc_while ()BEGIN    DECLARE num INT ;    SET num = 0 ;    WHILE num < 10 DO        SELECT            num ;        SET num = num + 1 ;    END WHILE ;END\\delimiter ;

repeat循环

delimiter \\CREATE PROCEDURE proc_repeat ()BEGIN    DECLARE i INT ;    SET i = 0 ;    repeat        select i;        set i = i + 1;        until i >= 5    end repeat;END\\delimiter ;

loop循环

iterate loop_label退出循环

BEGIN        declare i int default 0;    loop_label: loop                set i=i+1;        if i<8 then            iterate loop_label;        end if;        if i>=10 then            leave loop_label;        end if;        select i;    end loop loop_label;END

 

 

3、动态执行SQL语句

动态执行SQL语句,也就是执行一个存储过程来动态执行SQL语句

举例:有这样一张表

 

 

写一个存储过程无参,获取表里id大于11的数据

PREPARE prod FROM存储过程里将字符串解析为sql语句执行,后面跟字符串类型的sql语句

EXECUTE prod USING替换sql语句中的占位符,后面跟要替换占位符的、占位符变量,(sql语句中的占位符是?号)

 

delimiter $$DROP PROCEDURE IF EXISTS proc_sql $$ -- 判断proc_sql存储过程存在删除CREATE PROCEDURE proc_sql () -- 创建proc_sql存储过程BEGIN    declare p1 int;  -- 设置p1变量    set p1 = 11;     -- 赋值p1变量等于11    set @p1 = p1;    -- 赋值字符串占位符变量等于p1    PREPARE prod FROM 'select * from tb2 where nid > ?';  -- 解析字符串为sql语句    EXECUTE prod USING @p1;   -- 执行sql语句,并且用占位符变量替换sql语句中的?号    DEALLOCATE prepare prod;  -- 释放解析和执行sql语句END $$delimiter ;

执行存储过程,动态执行sql语句

CALL proc_sql();  -- 执行存储过程,动态执行sql语句

 

 

写一个存储过程有参,动态传参获取数据

delimiter $$DROP PROCEDURE IF EXISTS proc_sql $$ -- 判断proc_sql存储过程存在删除CREATE PROCEDURE proc_sql (          -- 创建proc_sql存储过程    in zfchsql CHAR(90),       --  zfchsql接收字符串最大90字符,接收sql语句    in shuzi INT(20)           --  shuzi接收整数类型,最大20字符,接收一个id数) BEGIN        -- 因为解析字符串为sql语句,和替换sql语句的占位符,需要用户变量,也就是有@的变量,所以需要重新赋值成用户变量        SET @zfchsql = zfchsql;        SET @shuzi = shuzi;    PREPARE prod FROM @zfchsql;  -- 将接收到的字符串解析为sql语句    EXECUTE prod USING @shuzi;   -- 将接收到的整数,替换sql语句中的?号占位符    DEALLOCATE prepare prod;  -- 释放解析和执行的sql语句END $$delimiter ;

传入参数动态执行sql语句

CALL proc_sql('select * from usr where id > ?',5);  -- 传入参数动态执行sql语句

 

 

重点:动态执行sql语句,可以防止sql注入,

CALL proc_sql('select * from usr -- where id > ?',5);  -- 传入参数动态执行sql语句

 

转载于:https://www.cnblogs.com/adc8868/p/7028827.html

你可能感兴趣的文章
VTK图形模型主要对象
查看>>
c# Linq实现 获得某一个路径下所有文件的名(不含扩展名)
查看>>
动静态广播的区别
查看>>
前缀式计算(前缀表达式)
查看>>
Linux常用命令大全
查看>>
添加删除tag
查看>>
ARM学习篇 中断定时理解
查看>>
卷积神经网络在tenserflow的实现
查看>>
[STL]用法
查看>>
PostgresException: 42883: function ifnull(integer, integer) does not exist
查看>>
python3 表情符号编码
查看>>
桥接模式
查看>>
跨server传输数据注意事项
查看>>
使用蒙版--渐变--制作瓶子倒影
查看>>
后代元素 span:first-child{...}
查看>>
LeetCode 540. 有序数组中的单一元素(Single Element in a Sorted Array) 42
查看>>
codevs 5958 无
查看>>
htaccess 实现网址缩短
查看>>
第四周作业&&结对编程
查看>>
12. 构造代码块
查看>>