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

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


前言

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


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

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

之前对这些字段的长度设定的是18 可利用sql:
SELECT column_name FROM information_schema.columns
where character_maximum_length=18 group by column_name;

其实我们数据库里面的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的目的,感觉是一次思维上的飞跃,又凭实力偷懒一次。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值