`
studentGuy1
  • 浏览: 15448 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Oracle 批量修改表字段类型

阅读更多

表空间下所有的表里CHAR类型的字段改成VARCHAR2,由于数据表字段太多,一个一个改太麻烦,所以我就想到了如下方式:

 

DECLARE
    CURSOR TEMP IS SELECT TABLE_NAME,COLUMN_NAME,DATA_LENGTH FROM USER_TAB_COLUMNS WHERE DATA_TYPE = 'CHAR';
    STR  VARCHAR2(100) := '';
  BEGIN 
      FOR S IN TEMP LOOP
        STR := 'ALTER TABLE '||S.TABLE_NAME||' MODIFY('||S.COLUMN_NAME||' VARCHAR2('||S.DATA_LENGTH||'))';
        DBMS_OUTPUT.PUT_LINE(STR);
      EXECUTE IMMEDIATE STR ;
      
      END LOOP;
  END;

 

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics