这里我的输入参数都是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也拼接不上去,导致下面的语法出现问题
*/ 

Logo

更多推荐