PostgreSQL之批量变更表名

PostgreSQL之批量变更表名,第1张

概述    最近做的项目中有个测试case需要从指定的schema下查找出指定前缀的所有表,然后删除指定表中关联的数据,测试的时候为了不至于 *** 作大几十张表,手动写了一个批量修改数据库表名的SQL,感觉还比较实用,记录一下。     实用过PgAdmin的人应该知道,需要查询出所有表名的信息一般是从pg_tables中获得,对应的SQL语句是: SELECT tablename FROM pg_

最近做的项目中有个测试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
 总结

以上是内存溢出为你收集整理的PostgreSQL之批量变更表名全部内容,希望文章能够帮你解决PostgreSQL之批量变更表名所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1175442.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存