我是靠谱客的博主 心灵美水蜜桃,最近开发中收集的这篇文章主要介绍第二百八十七节,MySQL数据库-条件语句、循环语句、动态执行SQL语句,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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语句

 

最后

以上就是心灵美水蜜桃为你收集整理的第二百八十七节,MySQL数据库-条件语句、循环语句、动态执行SQL语句的全部内容,希望文章能够帮你解决第二百八十七节,MySQL数据库-条件语句、循环语句、动态执行SQL语句所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(36)

评论列表共有 0 条评论

立即
投稿
返回
顶部