微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

postgresql 中 类似 oracle EXECUTE IMMEDIATE 的写法

pl/pgsql中,执行动态sql的格式如下(摘录自说明文档):

1
EXECUTEcommand-string[INTO[STRICT]target][usingexpression[,...]];

其中,

command-string就是要执行的动态sql语句(一定要记住:这里是sql语句,不是pl/pgsql语句,像raise notice就不能使用);

INTO子句是把sql查询到的值赋给INTO指定的变量;

using子句是前面的command-string中替代变量($1,$2,...)的赋值;

示例:

1
2
3
4
5
6
7
8
9
do$$
declare
v_c 1 integer;
v_c 2 integer;
begin
execute 'selectcount(*)asc1,count(*)asc2from(select1asidxunionselect11asidxunionselect21asidx)swhereidx>$1'
intov_c 1 ,v_c 2
using 10 ;
raisenotice '%,%' ,v_c 1 ,v_c 2 ;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐