postgresql 中 类似 oracle EXECUTE IMMEDIATE 的写法

前端之家收集整理的这篇文章主要介绍了postgresql 中 类似 oracle EXECUTE IMMEDIATE 的写法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

其中,

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$$@H_403_12@
declare@H_403_12@
v_c@H_403_12@ 1@H_403_12@ integer;@H_403_12@
v_c@H_403_12@ 2@H_403_12@ integer;@H_403_12@
begin@H_403_12@
execute@H_403_12@ 'selectcount(*)asc1,count(*)asc2from(select1asidxunionselect11asidxunionselect21asidx)swhereidx>$1'@H_403_12@
intov_c@H_403_12@ 1@H_403_12@ ,v_c@H_403_12@ 2@H_403_12@
using@H_403_12@ 10@H_403_12@ ;@H_403_12@

raisenotice@H_403_12@ '%,%'@H_403_12@ ,v_c@H_403_12@ 1@H_403_12@ ,v_c@H_403_12@ 2@H_403_12@ ;@H_403_12@

猜你在找的Postgre SQL相关文章