如何遍历字符串数组并在 Postgresql 中创建多个表

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)

kli*_*lin 8

循环变量应该只是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)

另请阅读文档: