Jsc*_*ore 3 postgresql loops plpgsql declare
我想拿一张大桌子,分成几个小桌子。我有以下代码片段,它通过手动替换"NAME"为 中的唯一名称来工作ui00000bvbb.lad15nm:
CREATE TABLE "NAME" AS
SELECT parcels_all_shapefile.* AS parcels
FROM ui00000bvbb INNER JOIN parcels_all_shapefile ON ST_Intersects(ui00000bvbb.wkb_geometry, parcels_all_shapefile.wkb_geometry)
WHERE ui00000bvbb.lad15nm = "NAME")
Run Code Online (Sandbox Code Playgroud)
我的问题是如何遍历名称列表并填充上述代码?我尝试了以下方法,但不起作用:
DO
$do$
DECLARE
m varchar[];
arr varchar[] := array[['Barnet'],['Westminster']];
BEGIN
FOREACH m SLICE 1 IN ARRAY arr
LOOP
CREATE TABLE m AS
SELECT parcels_all_shapefile.* AS parcels
FROM ui00000bvbb INNER JOIN parcels_all_shapefile ON ST_Intersects(ui00000bvbb.wkb_geometry, parcels_all_shapefile.wkb_geometry)
WHERE ui00000bvbb.lad15nm = m)
END LOOP;
END
$do$
Run Code Online (Sandbox Code Playgroud)
循环变量应该只是text. 在循环内使用简单FOREACH循环(不带SLICE)和动态 SQL EXECUTE:
DO
$do$
DECLARE
m text;
arr text[] := array['Barnet','Westminster'];
BEGIN
FOREACH m IN ARRAY arr
LOOP
EXECUTE format($fmt$
CREATE TABLE %1$I AS
SELECT parcels_all_shapefile.* AS parcels
FROM ui00000bvbb INNER JOIN parcels_all_shapefile ON ST_Intersects(ui00000bvbb.wkb_geometry, parcels_all_shapefile.wkb_geometry)
WHERE ui00000bvbb.lad15nm = %1$L
$fmt$, m);
END LOOP;
END
$do$
Run Code Online (Sandbox Code Playgroud)
另请阅读文档:
| 归档时间: |
|
| 查看次数: |
5494 次 |
| 最近记录: |