近期項目需要使用 oracle 數(shù)據(jù)庫尖昏,另項目使用 postgresql 做 gis 相關(guān)的工作爽丹,為了統(tǒng)一數(shù)據(jù)源,因此統(tǒng)一選擇了 postgresql 做基礎(chǔ)數(shù)據(jù)服務(wù)油啤。遷移時出現(xiàn) postgresql 區(qū)分大小寫的問題亿胸,因此查到如下方式進行將大小寫轉(zhuǎn)換為全小寫:
-- 創(chuàng)建exec(sqlstring)函數(shù)方便執(zhí)行
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
-- 根據(jù)條件查詢qrtz_calendars表坯钦,所有大寫的column
select * from information_schema.columns where table_schema = 'public'
-- 修改條件后,通過下列語句轉(zhuǎn)換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);
-- 查詢大寫的table_name
SELECT * FROM information_schema.TABLES WHERE table_schema = 'public' AND table_catalog = '庫名' 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 = '庫名'
and table_name <> lower(table_name);