• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

    字號: | 推薦給好友 上一篇 | 下一篇

    ORACLE ORA-1693錯誤以及表和索引的表空間的移動

    發布: 2008-2-03 16:31 | 作者: 胡天尺 | 來源: 希賽網 | 查看: 110次 | 進入軟件測試論壇討論

    領測軟件測試網  本公司開發的軟件,有客戶不能上傳大的附件,頁面不報任何錯誤。查看JBOSS日志,同樣看不到任何錯誤,排除了軟件本身故障。

      在查看oracle數據庫日志,發現當上傳大的附件時出現錯誤信息

      OEA_1693: MAX # EXTENTS 4096 reached in lobsegment

      nes.sys_LOB0000024832C00008$$

      解決過程

      上網找了下資料

      ORA-1693 max # extents (string) reached in lob segment string.string

      Cause: A LOB segment tried to extend past MAXEXTENTS.

      Action: If MAXEXTENTS is less than the system max, raise it. Otherwise, you must re-create with larger initial, next or PCTINCREASE parameters.

      將表空間的maxextents改為無限制,問題還是存在將該表的maxextents改為無限制

      alter table T_ID_CHECK_ACCESSORIES storage (maxextents unlimited)

      問題同樣不能解決

      后來在查看該表結構時意外發現該表用的表空間為USERS 而沒有用到我為其創建的表空間test,由于數據庫是用IMP導入數據的,可能是當初EXP導出時該用戶是用的oracle默認表空間。

      由于有以上發現我決定將該表的表空間修改為test

      Alter table T_ID_CHECK_ACCESSORIES move tablespace test;

      修改該表后測試系統 一切正常能正常傳大附件

      解決問題后還是一頭霧水,為什么該表用USERS表空間會出現ORA-01693問題,改為TEST表空間后正常,USERS和TEST的maxextents都為無限制。

      突然想到該用戶下面的所有表同樣都在USERS表空間中,決定把所有表都移至TEST中由于表較多所以用一個查詢生成所需要的命令

      Select ‘alter table ‘ || table_name || ‘ move tablespace test; ‘ from user_tables;

      然后執行該查詢所生成的結果

      將該用戶下的索引移至表空間TEST

      Select ‘alter index ‘|| index_name || ‘ rebuild tablespace test;’

      執行該查詢生成的命令后,發現有4個表報錯

      ORA-02327: cannot create index on expression with datatype LOB

      檢查4個表的結構后,都有個LOB字段那說明有LOB字段的索引不能用正常的

      alter index index_name rebuild talespace tablespace_name

      網上查詢得知我們要移動LOB的索引就必須使用特定的語法來移動LOB的對象,具體的語法如下:

      ALTER TABLE table_name MOVE

      TABLESPACE new_tbsp

      STORAGE(new_storage)                

      LOB (lobcol)                   --后面括號里面內容為  LOB 字段名

      STORE AS lobsegment

      (TABLESPACE new_tbsp

      STORAGE (new_storage));
     
      檢查是否有索引狀態為'UNUSABLE'select index_name from user_indexes t where t.status ='UNUSABLE';如果有則對該索引重建alter index index_name rebuild
     
      使用以上語法在修改這4條索引時,正常。!
     
      所有問題全部解決了,但很多地方還是一頭霧水(只怪自己太菜了)只有以后多加強學習,慢慢了解了。我的博客地址是:tianchi.csai.cn 大家來多交流哦!

    延伸閱讀

    文章來源于領測軟件測試網 http://www.kjueaiud.com/

    TAG: oracle Oracle ORACLE


    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
    北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備10010545號-5
    技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>