postgreSql使用||拼接sql实现一次性修改库里面所有字段的属性

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、先找出所有要修改的字段
  • 二、使用步骤
  • 总结


前言

需求要实现对所有数据库里面表中几个特定字段的长度完成修改,由于一个一个修改费神费时间,于是想到一个简单方法


提示:以下是本篇文章正文内容,下面案例可供参考

一、先找出所有要修改的字段

之前对这些字段的长度设定的是18 可利用sql:
SELECT column_name FROM information_schema.columns
where character_maximum_length=18 group by column_name;
postgreSql使用||拼接sql实现一次性修改库里面所有字段的属性_第1张图片
其实我们数据库里面的schema colum table相关信息都会被数据库记录下来 同样也是记录在表中,类似一些代码生成(比如自动生成增删改查sql)都是基于这个来做的。
具体可以参考:https://blog.csdn.net/iteapoy/article/details/89386252

二、使用步骤

获取到我们需要修改的列名后 就可以使用稍微偷懒一点的方式去修改各个数据库里面字段的属性了
修改colum字段长度的语法为:
ALTER able_name alter COLUMN column_name SET DATA TYPE varchar(40);
将所有我们需要修改的列名和表名查询出来:
SELECT table_name, column_name FROM information_schema.columns
where column_name in (‘colum01’, ‘colum02’, ‘colum03’, ‘colum04’)
and character_maximum_length=18 order by table_name

其实到这里就可以去根据列名和表名记录去替换一条一条执行了 但其实我们可以让数据库帮我们将这些sql写出来

我们可以这样:
SELECT ‘ALTER table ‘||table_name||’ alter COLUMN ‘||column_name||’ SET DATA TYPE varchar(40);’ FROM information_schema.columns
where column_name in (‘comp_pn’, ‘material’, ‘parent_pn’, ‘sci_material’)
and character_maximum_length=18 order by table_name ;

这样查询出来的数据就是一条一条可以执行的sql 直接copy到数据库执行就可以啦 (可能会有表名后缀为default的表,直接过滤就行)


总结

利用数据库的拼接符 || 实现组装sql的目的,感觉是一次思维上的飞跃,又凭实力偷懒一次。

你可能感兴趣的:(sql,postgresql,数据库)