posts - 60,comments - 71,trackbacks - 0

                  在ORACLE數據庫表中,有時會有需要更改數據庫表中字段類型的情況,比如由NUMBER(5)改為
          VARCHAR(50)...,這時就要視情況來更改了,如果原數據庫表中沒有數據,則可以直接使用:
                          
                alter   table  test  modify  name  VARCHAR2(50);

                 但是有數據的話 就不能用上面方法了,

                   

                 alter table test add  name_temp number(5);
                        
                  
          update test set  name_temp=name;

                  
          alter table drop column name;

                   
          alter  table  test rename column  name_temp to name;

                  這種方法會使列名發生變化,而且字段順序增加 有可能發生行遷移,對應用程序會產生影響

                  以下方法是比較好的方法

                  不用使列名發生變化 也不會發生表遷移,但這個有個缺點是表要更新兩次

                  如果數據量較大的話 產生的undo和redo更多 ,前提也是要停機做

                  要是不停機的話 ,也可以采用在線重定義方式來做

                  以下是腳本:

                 alter table test  add name_temp number(5);

                 
          update  test  set name_temp=name,name=null;

                 
          alter table  test  modify name  VARCHAR2(50);
                 
                     update  test  set name=name_temp,name_temp=null;
                 
                     commit;
                 
                     alter table  test  drop column name_temp;
              
                  
          desc test;
                   
                    這樣就不會出現上述的問題了.
          posted on 2009-03-04 11:42 henry1451 閱讀(852) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 万荣县| 布尔津县| 三穗县| 县级市| 盘山县| 丹凤县| 长岛县| 苗栗市| 神池县| 凉城县| 周宁县| 梅河口市| 彭泽县| 海门市| 阳曲县| 宁晋县| 浪卡子县| 图片| 米泉市| 韶山市| 盖州市| 花莲市| 株洲县| 图片| 漳平市| 香河县| 东莞市| 外汇| 怀宁县| 陆河县| 西乌| 南陵县| 来凤县| 双柏县| 墨江| 玛纳斯县| 敖汉旗| 长子县| 东山县| 沛县| 神池县|