SET citus.next_shard_id TO 380000; -- =================================================================== -- test INSERT proxy creation functionality -- =================================================================== -- use transaction to permit multiple calls to proxy function in one session BEGIN; -- use "unorthodox" object names to test quoting CREATE SCHEMA "A$AP Mob" CREATE TABLE "Dr. Bronner's ""Magic"" Soaps" ( id bigint PRIMARY KEY, data text NOT NULL DEFAULT 'lorem ipsum' ); \set insert_target '"A$AP Mob"."Dr. Bronner''s ""Magic"" Soaps"' -- create proxy and save proxy table name SELECT create_insert_proxy_for_table(:'insert_target') AS proxy_tablename \gset -- insert to proxy, relying on default value INSERT INTO pg_temp.:"proxy_tablename" (id) VALUES (1); -- copy some rows into the proxy COPY pg_temp.:"proxy_tablename" FROM stdin; 2 dolor sit amet 3 consectetur adipiscing elit 4 sed do eiusmod 5 tempor incididunt ut 6 labore et dolore \. -- verify rows were copied to target SELECT * FROM :insert_target ORDER BY id ASC; -- and not to proxy SELECT count(*) FROM pg_temp.:"proxy_tablename"; ROLLBACK; -- test behavior with distributed table, (so no transaction) CREATE TABLE insert_target ( id bigint PRIMARY KEY, data text NOT NULL DEFAULT 'lorem ipsum' ); -- squelch WARNINGs that contain worker_port SET client_min_messages TO ERROR; SET citus.shard_count TO 2; SET citus.shard_replication_factor TO 1; SELECT create_distributed_table('insert_target', 'id', 'hash'); CREATE TEMPORARY SEQUENCE rows_inserted; SELECT create_insert_proxy_for_table('insert_target', 'rows_inserted') AS proxy_tablename \gset -- insert to proxy, again relying on default value INSERT INTO pg_temp.:"proxy_tablename" (id) VALUES (1); -- test copy with bad row in middle \set VERBOSITY terse COPY pg_temp.:"proxy_tablename" FROM stdin; 2 dolor sit amet 3 consectetur adipiscing elit 4 sed do eiusmod 5 tempor incididunt ut 6 labore et dolore 7 \N 8 magna aliqua \. \set VERBOSITY default -- verify rows were copied to distributed table SELECT * FROM insert_target ORDER BY id ASC; -- the counter should match the number of rows stored SELECT currval('rows_inserted'); SET client_min_messages TO DEFAULT;