我是靠谱客的博主 高大天空,最近开发中收集的这篇文章主要介绍Postgresql 存储过程--sql语句的where条件的拼接操作,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1、存储过程返回一个表

CREATE OR REPLACE FUNCTION 存储过程名(

    IN 参数1text,
    IN 参数2text,
    IN 参数3text)
  RETURNS TABLE(v_id integer, v_n text, v_me text, v_sid integer, v_sno integer, v_sname text) AS
$BODY$


DECLARE sql text;

BEGIN   
       sql:='SELECT a.sid,a.no,a.name,b.sid,b.no,b.name
FROM  表名 a
INNER JOIN 表名 b ON a.station_id = b.sid';


       IF 参数1= '' AND 参数2= '' AND 参数3= '' THEN
RETURN QUERY EXECUTE sql;

        ELSEIF 参数1= '' AND 参数2 = '' THEN
          sql:= sql || ' WHERE b.no = '''||in_stationNo||'''';
          RETURN QUERY EXECUTE sql;


        ELSEIF 参数2 = '' AND 参数3= '' THEN
           sql:= sql || '   WHERE a.name LIKE ''%'||参数1||'%''';
           RETURN QUERY EXECUTE sql;
        
        ELSEIF 参数1= '' AND 参数3= '' THEN
           sql:= sql || '   WHERE a.no LiKE ''%'||参数2||'%''';
           RETURN QUERY EXECUTE sql;


        ELSEIF 参数1= '' THEN
           sql:= sql || '   WHERE a.name LIKE ''%'||参数2||'%''AND b.no = '''||参数3||'''';
            RETURN QUERY EXECUTE sql;


        ELSEIF 参数2= '' THEN
            sql:= sql || '   WHERE a.no LIKE ''%'||参数1||'%''AND b.no = '''||参数3||'''';
            RETURN QUERY EXECUTE sql;


        ELSEIF 参数3= '' THEN
            sql:= sql || '   WHERE a.name LIKE ''%'||参数2||'%''AND a.no LIKE ''%'||参数1||'%''';
            RETURN QUERY EXECUTE sql;
        ELSE
             sql:= sql || '   WHERE a.name LIKE ''%'||参数2||'%''AND a.no LIKE ''%'||参数1||'%''AND b.no = '''||参数3||'''';
            RETURN QUERY EXECUTE sql;
              END IF;
END
$BODY$
  LANGUAGE plpgsql VOLATILE;

最后

以上就是高大天空为你收集整理的Postgresql 存储过程--sql语句的where条件的拼接操作的全部内容,希望文章能够帮你解决Postgresql 存储过程--sql语句的where条件的拼接操作所遇到的程序开发问题。

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

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

评论列表共有 0 条评论

立即
投稿
返回
顶部