調整表的CHAR/VARCHAR2欄位的Byte為CHAR

來源:互聯網
上載者:User

調整表的CHAR/VARCHAR2欄位的Byte為CHAR

使用如下SQL指令碼即可:

  1. set serveroutput on  
  2. DECLARE  
  3. sqlstr varchar2(4000);  
  4. cursor sqlcurs is  
  5. select owner,table_name,column_name,data_type,CHAR_LENGTH from dba_tab_columns   
  6. where owner='ZFPT'  
  7. and data_type in ('CHAR','VARCHAR2') order by table_name,column_id;  
  8. begin  
  9. for str in sqlcurs loop  
  10.     sqlstr:='ALTER TABLE '||str.owner||'.'||str.table_name||' MODIFY('||str.column_name||' '||str.data_type||'('||str.CHAR_LENGTH||' CHAR'||'))';  
  11.     dbms_output.put_line(sqlstr);  
  12.     --execute immediate sqlstr;   
  13. end loop;  
  14. end;  
  15. /  

註:對於那些作為分區列的欄位不能修改,會出現如下錯誤,並且會退出,所以最好是把命令輸出到一個sql指令碼裡面,然後在sqlplus命令列裡面去執行,也可以寫成預存程序然後捕獲異常並繼續。

ERROR at line 1:
ORA-14060: data type or length of a table partitioning column may not be changed
ORA-06512: at line 10

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.