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;


    通过对比可以发现,我们平常实用的tablename其实是从pg_class基表的relname得来的,其实pg_class基表就是一个管理对应schema下面表名的系统表,所有其他一般表的表名都是依赖这张基表,明白这点后,就可以大、方便的修改一般表的表名了:

 

/* 修改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_%'


另外,如果再编程当中想先通过pg_tables 查询指定的表名,再将表名当做参数传递到Mybatis的动态SQL文当中的话,只需要将Mybatis的参数定义#{}修改为${}即可,

如下:

 

DELETE FROM ${tableName} WHERE

 

 



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值