PostgreSQL 动态SQL语句怎么写

 我来答
克祥昭我铭3
推荐于2016-01-08 · TA获得超过4017个赞
知道大有可为答主
回答量:2198
采纳率:100%
帮助的人:3308万
展开全部

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;
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式