PostgreSQL之批量变更表名
最近做的项目中有个测试case需要从指定的schema下查找出指定前缀的所有表,然后删除指定表中关联的数据,测试的时候为了不至于操作大几十张表,手动写了一个批量修改数据库表名的SQL,感觉还比较实用,记录一下。 实用过PgAdmin的人应该知道,需要查询出所有表名的信息一般是从pg_tables中获得,对应的SQL语句是: SELECT tablename FROM pg_tables WHERE tablename like 'imfr_ut_%' 但是pg_tables并不是一张系统基表,而是一个试图View。 CREATE OR REPLACE VIEW pg_tables AS SELECT n.nspname AS schemaname,c.relname AS tablename,pg_get_userbyid(c.relowner) AS tableowner,t.spcname AS tablespace,c.relhasindex AS hasindexes,c.relhasrules AS hasrules,c.relhastriggers AS hastriggers FROM pg_class c LEFT JOIN pg_namespace n ON n.oid = c.relnamespace LEFT JOIN pg_tablespace t ON t.oid = c.reltablespace WHERE c.relkind = 'r'::"char"; ALTER TABLE pg_tables OWNER TO postgres; GRANT SELECT ON TABLE pg_tables TO public;
/* 修改SQL */ update pg_class set relname = 'test_'||relname where relname like 'imfr_ut_% 这样就不需要备份重建一张表,就可以轻轻松松的修改表名了 下面是复原SQL /* 恢复SQL */ update pg_class set relname = substring(relname,6) where relname like 'test_imfr_ut_%'
如下: DELETE FROM ${tableName} WHERE
??
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |