PostgreSQL 大小写问题 一键修改表名、字段名为小写 阅读模式
标准的SQL是不区分大小写的。但是PostgreSQL对于数据库中对象的名字允许使用支持大小写区分的定义和引用方法。方式就是在DDL中用双引号把希望支持大小的对象名括起来。
比如希望创建一个叫AAA的表。如果用CREATE TABLE AAA (...);的话,创建出来的表实际上是aaa。
如果希望创建大写的AAA表的话,就需要用CREATE TABLE "AAA" (...);这种双引号的方式定义对象名。
这样写的缺点是查询语句必须也使用双引号的方式引用对象名。比如SELECT * FROM "AAA";否则PostgreSQL缺省会去找aaa这个对象,然后返回aaa不存在的错误。需要注意的是不仅仅是表可以这样定义和引用,对PostgreSQL中的任意对象(比如列名,索引名等)都有效。
创建exec(sqlstring)
函数方便执行
CREATE OR REPLACE FUNCTION "public"."exec"("sqlstring" varchar) RETURNS "pg_catalog"."varchar" AS $BODY$ declare res varchar(50); BEGIN EXECUTE sqlstring; RETURN 'ok'; END $BODY$ LANGUAGE plpgsql VOLATILE COST 100
通过条件拼接SQL,修改某表 column为小写
-- 根据条件查询qrtz_calendars表,所有大写的column select * from information_schema.columns where table_schema = 'public' and table_name = 'qrtz_calendars' -- 修改条件后,通过下列语句转换column_name中的大写字母 SELECT exec('alter table "' || table_name || '" rename column "' || column_name || '" to ' || lower( column_name ) || ';') FROM information_schema.COLUMNS WHERE table_schema = 'public' AND column_name <> lower(column_name) AND table_name = 'qrtz_triggers';
修改表名为小写
-- 查询大写的table_name SELECT * FROM information_schema.TABLES WHERE table_schema = 'public' AND table_catalog = 'Guns' AND table_name <> lower( table_name ); -- 修改表名中的大写为小写 SELECT exec ( 'alter table "' || table_name || '" rename to ' || lower( table_name ) || ';' ) FROM information_schema.tables WHERE table_schema='public' and table_catalog = 'Guns' and table_name <> lower(table_name);
分类:
PostgreSQL 与 PostGIS
, 数据库
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析