PostgreSQL 动态SQL语句怎么写
4个回答
展开全部
PostgreSQL的PL/pgSQL语言是支持动态SQL语句的(说execute immediate的是ECPG所支持的)。但是,要记得重要的一点: 是在PL/pgSQL语言中支持。而PL/pgSQL语言一个块结构的语言,它以begin ... end为块的开始与结束标识。这也就是说,要执行动态SQL语句,就必须放到begin ... end块中,而不要想实现一个单独的动态SQL语句。在SQL Server中,倒是可以轻松的实现,我们可以直接执行一个这样的动态SQL:
execute sp_executesql N'select 1 as val'
而在PostgreSQL中,就不要有此想法了。当然,SQL Server的这种动态SQL语句的执行方法也有其局限与不便的地方。
在PL/pgSQL中,执行动态SQL的格式如下(摘录自说明文档):
EXECUTE command-string [ INTO [STRICT] target ] [ USING expression [, ... ] ];
其中,
command-string就是要执行的动态SQL语句(一定要记住:这里是SQL语句,不是PL/pgSQL语句,像raise notice就不能使用);
INTO子句是把SQL查询到的值赋给INTO指定的变量;
USING子句是前面的command-string中替代变量($1, $2, ...)的赋值;
示例:
do $$
declare
v_c1 integer;
v_c2 integer;
begin
execute 'select count(*) as c1, count(*) as c2 from (select 1 as idx union select 11 as idx union select 21 as idx) s where idx > $1'
into v_c1, v_c2
using 10;
raise notice '%, %', v_c1, v_c2;
展开全部
只是调用执行函数,就是一个select f_name()。
动态执行SQL和Oracle的execute immediate类似,如:
execute 'select '''||123||'''' into v_temp;
函数里调用函数可以用perform f_name();
动态执行SQL和Oracle的execute immediate类似,如:
execute 'select '''||123||'''' into v_temp;
函数里调用函数可以用perform f_name();
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
动态执行SQL和Oracle的execute immediate类似,如:
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
哈哈,终于找到一个使用一样数据库的了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询