mysql 存储过程输入参数当做where条件的三种方式

这里我的输入参数都是ps_name

第一种:通过字符串拼接

BEGIN
DECLARE $sqltext VARCHAR(1000);
SET $sqltext = 'SELECT * FROM user where 1=1';
IF ps_name IS NOT NULL THEN
SET $sqltext = CONCAT($sqltext,' and name = \'',ps_name,'\'');
END IF;
SELECT $sqltext;# 输出拼接sql语句,相当于print
SET @querysql = $sqltext;
PREPARE tmpsql FROM @querysql;#这里为什么要用用户变量而不是直接用局部变量,可以参考博客:https://blog.csdn.net/liuxiao723846/article/details/42869999;https://bbs.csdn.net/topics/390619669?page=1
EXECUTE tmpsql;
DEALLOCATE PREPARE tmpsql;
END

第二种:使用or就完事了

BEGIN
    SELECT * FROM `user` WHERE 1=1 AND (ps_name IS NULL OR `name` = ps_name);
    #存储过程传入变量当做查询条件,这是我认为最好的一种方式。
END

第三种:通过if条件直接写两种sql

BEGIN
    IF ps_name IS NOT NULL
    THEN SELECT * FROM `user` WHERE name = ps_name;
    ELSE SELECT * FROM `user`;
    END IF;
END

 

#我在想有没有第四种方式即直接通过传入变量来拼接where条件,而不是像第一种通过拼接字符串的形式来完成,下面给出一个例子吧,有空研究下。
/*SELECT * FROM `user` WHERE 1=1
    IF ps_name IS NOT NULL
    THEN AND name = ps_name;
    ELSE ;
    END IF;
后来我想了一下,我觉得这个方式不行,因为if是一个独立的语句片段,而SELECT * FROM `user` WHERE 1=1却没有用;分隔,就算分隔了,
下面的and也拼接不上去,导致下面的语法出现问题
*/ 

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值