PostgreSQL源码学习笔记-查询执行
    		       		warning:
    		            这篇文章距离上次修改已过423天,其中的内容可能已经有所变动。
    		        
        		                
                
-- 创建一个新的查询描述树,用于执行查询
EXECUTE pg_catalog.plpgsql_create_query_desc(
    'SELECT * FROM pg_catalog.pg_class WHERE oid = $1',
    '{}',
    '{}',
    0
);
 
-- 准备查询,为执行做准备
EXECUTE pg_catalog.plpgsql_prepare(
    'my_query', -- 准备的名称
    'SELECT * FROM pg_catalog.pg_class WHERE oid = $1', -- 查询字符串
    '{}' -- 参数类型
);
 
-- 执行准备好的查询
EXECUTE pg_catalog.plpgsql_execute('my_query', pg_catalog.array_append(pg_catalog.current_schemas(TRUE), 'pg_catalog'));
 
-- 解除准备的查询
EXECUTE pg_catalog.plpgsql_unprepare('my_query');这个例子展示了如何在PL/pgSQL中准备和执行一个查询。它首先创建了一个查询描述树,然后准备了一个查询,接着执行它,并在最后释放所准备的查询。这个过程是动态SQL执行的一个常见模式。
评论已关闭