今天在编写业务的存储过程时,需要使用到AND条件的拼接,而根据业务逻辑要求存在多达10种排列组合,以往只有两三种排列组合时,我直接使用了PL/SQL的IF语句分支进行判断,简洁明了。
由于排列组合较多,并且sql语句也一致,便希望将sql抽取出来,作为全局的sql,再由WHERE拼接语句。这样一来,排列组合一次sql一次的情况得以解决,存储过程的代码冗余也就大大降低了。
使用参数游标,即: [参数名] OUT sys_refcursor
游标最基本的使用方式,PL/SQL如下:
OPEN myCur FOR
SELECT * FROM person;
那如果需要在存储过程中使用输出游标结合动态sql拼接,该如何做呢?
例子如下:
DECLARE
p_person_id varchar(255);
p_person_phone varchar(255);
SQL_Text varchar2(32760) := 'SELECT * FROM person WHERE 1 = 1 ';
myCur sys_refcursor;
BEGIN
IF p_person_id IS NOT NULL THEN
SQL_Text := SQL_Text || 'AND person_id = '' ' || p_person_id || ''' ';
END IF;
IF p_person_phone IS NOT NULL THEN
SQL_Text := SQL_Text || 'AND person_phone = '' ' || p_person_phone || ''' ';
END IF;
dbms_output.put_line(SQL_Text);
OPEN myCur FOR SQL_Text;
END;
注意事项:
原文:https://www.cnblogs.com/zhuang229/p/12381294.html