BEGIN; CREATE TEMP SEQUENCE table_seq; SELECT setval('table_seq', (SELECT max(tab_id) FROM _slony.sl_table)); CREATE TEMP SEQUENCE seq_seq; SELECT setval('seq_seq', (SELECT max(seq_id) FROM _slony.sl_sequence)); SELECT 'SET ADD TABLE (SET ID=@temp, ORIGIN=@master, ID='||nextval('table_seq')||', fully qualified name = '''||fullname||''''||(case when have_pk then ');' else ', key='''||uniq_index||''');' end) FROM ( SELECT n.nspname||'.'||c.relname AS fullname, (SELECT exists (SELECT indexrelid from pg_catalog.pg_index WHERE indisprimary is true AND indisvalid is true AND indrelid=c.oid)) AS have_pk, (SELECT c1.relname from pg_catalog.pg_index i JOIN pg_catalog.pg_class c1 ON c1.oid=i.indexrelid WHERE i.indisprimary is false AND i.indisunique is true AND i.indisvalid is true AND i.indrelid=c.oid AND NOT EXISTS ( SELECT i_attr.attname FROM pg_catalog.pg_attribute t_attr JOIN pg_catalog.pg_attribute i_attr ON i_attr.attname=t_attr.attname AND i_attr.attrelid = i.indexrelid WHERE t_attr.attrelid = c.oid AND t_attr.attnotnull <> 't' ) ORDER BY 1 LIMIT 1) AS uniq_index FROM pg_catalog.pg_class c JOIN pg_namespace n ON n.oid = c.relnamespace WHERE c.relkind = 'r'::"char" AND n.nspname NOT LIKE 'pg_%' AND n.nspname NOT IN ('_slony', 'information_schema', 'tables_to_drop') AND NOT EXISTS (select 1 from _slony.sl_table WHERE tab_relname=c.relname AND tab_nspname=n.nspname) ORDER BY have_pk desc, fullname ) AS t1 WHERE (have_pk IS TRUE OR uniq_index IS NOT NULL) UNION ALL SELECT 'SET ADD SEQUENCE (SET ID=@temp, ORIGIN=@master, ID='||nextval('seq_seq')||', fully qualified name = '''||fullname||''');' FROM ( SELECT n.nspname||'.'||c.relname AS fullname FROM pg_catalog.pg_class c JOIN pg_namespace n ON n.oid = c.relnamespace WHERE c.relkind = 'S'::"char" AND n.nspname NOT LIKE 'pg_%' AND n.nspname NOT IN ('_slony', 'information_schema', 'tables_to_drop') AND NOT EXISTS (select 1 from _slony.sl_sequence WHERE seq_relname=c.relname AND seq_nspname=n.nspname) ORDER BY fullname ) AS t1; COMMIT;