Oracle如何批量將表中字段名全轉(zhuǎn)換為大寫(利用簡單存儲過程)
前言
今天查詢一個(gè)數(shù)據(jù)字段一直提示字符無效,明明在數(shù)據(jù)庫表字段中是存在的;
查詢后得知,數(shù)據(jù)庫表字段為小寫時(shí),查詢需要將字段名小寫并加上雙引號;
表名同理,我這里表名是大寫,暫時(shí)不需要改。
搜到一個(gè)批量修改字段名為大寫的存儲過程,如下:
登陸到要修改的用戶下,
執(zhí)行:
begin
for cl in (SELECT table_name,column_name from user_tab_columns WHERE column_name<>upper(column_name) and upper(column_name) not in('SIZE','CHECK')) loop
begin
execute immediate 'alter table '||cl.table_name||' rename column "'|| cl.column_name ||'" to '||upper(cl.column_name);
exception
when others then
dbms_output.put_line(cl.table_name||'.'||cl.column_name||'已存在');
end;
end loop;
end;
即完成該用戶下所有表字段名改為大寫的過程。
附上批量修改表名為大寫的存儲過程,以備后用:
-- oracle 批量修改表名為大寫(當(dāng)前登錄用戶) begin for c in (select table_name tn from user_tables where table_name <> upper(table_name)) loop begin execute immediate 'alter table "'||c.tn||'" rename to '||c.tn; exception when others then dbms_output.put_line(c.tn||'已存在'); end; end loop; end;
再附 字段類型批量修改(此時(shí)表內(nèi)無內(nèi)容):
DECLARE
CURSOR TEMP IS SELECT TABLE_NAME,COLUMN_NAME,DATA_LENGTH FROM USER_TAB_COLUMNS WHERE DATA_TYPE = 'NVARCHAR2' AND ROWNUM < 100;
STR VARCHAR2(100) := '';
BEGIN
FOR S IN TEMP LOOP
STR := 'ALTER TABLE '||S.TABLE_NAME||' MODIFY('||S.COLUMN_NAME||' VARCHAR2(200))';
DBMS_OUTPUT.PUT_LINE(STR);
EXECUTE IMMEDIATE STR ;
END LOOP;
END;
到此這篇關(guān)于Oracle如何批量將表中字段名全轉(zhuǎn)換為大寫(利用簡單存儲過程)的文章就介紹到這了,更多相關(guān)Oracle批量將表字段名轉(zhuǎn)換為大寫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
CentOS系統(tǒng)上安裝配置Oracle數(shù)據(jù)庫的詳細(xì)教程
這篇文章主要介紹了CentOS系統(tǒng)上安裝配置Oracle數(shù)據(jù)庫的詳細(xì)教程,包括安裝過程中一些常見錯(cuò)誤問題的解決,需要的朋友可以參考下2016-03-03
如何使用GDAL庫的ogr2ogr將GeoJSON數(shù)據(jù)導(dǎo)入到PostgreSql中
本文主要介紹了PyTorch中的masked_fill函數(shù)的基本知識和使用方法,masked_fill函數(shù)接受一個(gè)輸入張量和一個(gè)布爾掩碼作為主要參數(shù),掩碼的形狀必須與輸入張量相同,掩碼操作根據(jù)掩碼中的布爾值在輸出張量中填充指定的值或保留輸入張量中的值2024-10-10
Oracle 11g收集多列統(tǒng)計(jì)信息詳解
我們在寫SQL語句的時(shí)候,有的時(shí)候會碰到where子句后面有多個(gè)條件的情況,也就是根據(jù)多列的條件篩選得到數(shù)據(jù)。下面這篇文章主要給大家介紹了Oracle 11g收集多列統(tǒng)計(jì)信息的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考下。2017-03-03
Oracle數(shù)據(jù)庫升級或數(shù)據(jù)遷移方法研究
本文詳細(xì)論述了oracle數(shù)據(jù)庫升級的升級前的準(zhǔn)備、升級過程和升級后的測試與調(diào)整工作,并對各種升級方法在多種操作系統(tǒng)平臺上作了測試。2016-07-07

