廊坊新聞網(wǎng)-主流媒體,廊坊城市門戶

    Oracle 刪除大量表記錄操作總結

    2023-09-09 11:45:07 來源:中年農碼工

    刪除表數(shù)據(jù)操作


    (資料圖片僅供參考)

    清空所有表記錄

    TRUNCATE TABLE your_table_name;

    或者批量刪除滿足條件的表記錄

    BEGIN  LOOP    DELETE FROM your_table_name WHERE rownum <= 50000;      EXIT WHEN SQL%ROWCOUNT = 0;   COMMIT; END LOOP;END;

    釋放表空間

    存放大數(shù)據(jù)量的表,其表空間占用也比較大,刪除數(shù)據(jù)后并不會自動釋放這些記錄占用的表空間,所以,即便表里面數(shù)據(jù)量很少,查詢效率依舊很慢,所以,需要釋放表空間。

    -- 查詢數(shù)據(jù)表占用的表空間大小SELECT sum(bytes)/(1024*1024) FROM user_segments WHERE segment_name="YOUR_TABLE_NAME"; --注意,表名必須大寫

    說明: sum(bytes)/(1024*1024) 數(shù)據(jù)統(tǒng)計單位由Byte轉為GB

    --整理碎片,釋放已刪除記錄占用的表空間ALTER TABLE your_table_name MOVE;

    重建索引

    釋放了表空間以后表的ROWID會發(fā)生變化,基于ROWID的索引會失效,此時就需要重建索引

    --重建非分區(qū)索引ALTER TABLE your_table_index REBUILD [ONLINE] [NOLOGGING];--重建分區(qū)索引--針對分區(qū)索引-非組合索引ALTER INDEX your_table_index REBUILD PARTITION your_partition_name [ONLINE] [NOLOGGING];

    注意:

    設置日志級別為 NOLOGGING 意味盡量減少日志,可以加速索引重建 ONLINE , NOLOGGING 兩者位置順序可以對調,不影響 普通情況下建立索引或者REBUILD索引時,oracle會對基表加共享鎖,在這期間,無法對表進行DML操作。如果希望避免這種情況,需要加 ONLINE 選項 對索引進行REBUILD時,如果不加 ONLINE 選項,則Oracle直接讀取原索引的數(shù)據(jù),否則直接掃描表中的數(shù)據(jù) ,索引在重建時,查詢仍然可以使用舊索引。實際上,Oracle在REBUILD索引的過程中,并不會刪除舊索引,直到新索引重建成功,這就是相對刪除索引然后重建索引的一個好處:不會影響原有的SQL查詢。但也正由于此,用REBUILD方式建立索引需要相應表空間的空閑空間是刪除重建方式的2倍。 不能直接REBUILD整個分區(qū)索引 對于非組合索引,需要REBUILD每個分區(qū)(partition) 對于組合索引,需要REBUILD每個子分區(qū)(subpartition) 分區(qū)、子分區(qū)較多的情況下,可以使用下面的SQL可以生成相應的REBUILD語句 --重建分區(qū)索引-非組合索引 SELECT "ALTER INDEX " || index_owner || "." || index_name || " REBUILD PARTITION " || partition_name || " NOLOGGING;" FROM dba_ind_partitions WHERE index_owner = "INDEX_OWNER_NAME" --可選查詢條件,注意,如果指定該條件,索引擁有者必須大寫 AND index_name = "YOUR_INDEX_NAME" ; --注意,索引名稱必須大寫 --重建分區(qū)索引-組合索引 SELECT "ALTER INDEX " || index_owner || "." || index_name || " REBUILD SUBPARTITION " || subpartition_name || " NOLOGGING;" FROM dba_ind_subpartitions WHERE index_owner = "INDEX_OWNER_NAME" --可選查詢條件,注意,如果指定該條件,索引擁有者必須大寫 AND index_name = "YOUR_INDEX_NAME" ; --注意,索引名稱必須大寫 針對非分區(qū)索引,如果清理的表比較多,或者不知道被清理的表擁有哪些索引,可以使用以下SQL查詢并生成對應的重建索引SQL SELECT concat(concat( "ALTER INDEX " , INDEX_NAME), " REBUILD;" ) FROM all_indexes WHERE owner = "INDEX_OWNER_NAME" --可選查詢條件,注意,如果指定該條件,索引擁有者必須大寫 AND table_name IN ( "TABLE_NAME1 " , "TABLE_NAME2" , "..." , "TABLE_NAMEN" ) --注意,表名必須大寫

    分析表

    分析表,是為了使基于CBO的執(zhí)行計劃更加準確,在一定程度上能帶來一些性能提升

    ANALYZE TABLE table_name COMPUTE STATISTICS;--等價于ANALYZE TABLE table_name COMPUTE STATISTICS FOR TABLE FOR ALL INDEXES FOR ALL COLUMNS;

    說明:生成的統(tǒng)計信息的存放位置:

    FOR TABLE 的統(tǒng)計信息存在于視圖: USER_TABLES 、 ALL_TABLES 、 DBA_TABLES FOR ALL INDEXES 的統(tǒng)計信息存在于視圖: USER_INDEXES 、 ALL_INDEXES 、 DBA_INDEXES FOR ALL COLUMNS 的統(tǒng)計信息存在于試圖: USER_TAB_COLUMNS 、 ALL_TAB_COLUMNS 、 DBA_TAB_COLUMNS

    關鍵詞:

    亚洲一区中文字幕在线观看| 亚洲美女视频网站| 国产亚洲成av片在线观看| 亚洲变态另类一区二区三区| 亚洲精品免费在线视频| 亚洲国产精品不卡在线电影| 亚洲宅男天堂在线观看无病毒| 亚洲成aⅴ人片久青草影院| 亚洲Aⅴ在线无码播放毛片一线天| 亚洲精品无码久久久久秋霞| 亚洲一卡2卡三卡4卡无卡下载| 亚洲Av高清一区二区三区| 亚洲一区二区三区在线| 亚洲网站免费观看| 亚洲精品在线网站| 亚洲国产成人精品无码一区二区| 亚洲精品亚洲人成在线观看麻豆| 亚洲无删减国产精品一区| 亚洲精品无码乱码成人| 亚洲中文字幕久久精品无码APP| 亚洲综合色成在线播放| 亚洲天堂免费在线视频| 在线观看亚洲精品福利片| 亚洲综合伊人久久综合| 国产偷v国产偷v亚洲高清| 亚洲AV永久无码区成人网站| 成人亚洲性情网站WWW在线观看| 久久亚洲精品无码观看不卡| 亚洲综合另类小说色区| 日本亚洲视频在线| 亚洲AV无码一区二区三区国产| 内射无码专区久久亚洲| 亚洲精品国产自在久久| 亚洲日本乱码在线观看| 亚洲成AV人片在WWW色猫咪| 精品亚洲成a人片在线观看少妇| 亚洲欧洲视频在线观看| 亚洲综合色一区二区三区| 亚洲AV无码一区二区三区久久精品| 一区二区三区亚洲视频| 亚洲综合伊人久久综合|