PostgreSQL 动态SQL语句怎么写

 我来答
Andy_Sun321
推荐于2017-12-15 · TA获得超过1376个赞
知道小有建树答主
回答量:811
采纳率:89%
帮助的人:727万
展开全部

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;
N_0_1
高粉答主

推荐于2016-07-10 · 关注我不会让你失望
知道大有可为答主
回答量:8628
采纳率:47%
帮助的人:832万
展开全部
只是调用执行函数,就是一个select f_name()。
动态执行SQL和Oracle的execute immediate类似,如:
execute 'select '''||123||'''' into v_temp;
函数里调用函数可以用perform f_name();
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
0808xyj
2014-12-05 · TA获得超过1891个赞
知道大有可为答主
回答量:1237
采纳率:100%
帮助的人:1077万
展开全部
动态执行SQL和Oracle的execute immediate类似,如:
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
chars_chan
2014-12-11
知道答主
回答量:12
采纳率:0%
帮助的人:6.2万
展开全部
哈哈,终于找到一个使用一样数据库的了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式