国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Oracle 刪除大量表記錄操作分析總結(jié)

瀏覽:148日期:2023-03-12 15:25:15
目錄
  • 刪除表數(shù)據(jù)操作
  • 釋放表空間
  • 重建索引
  • 分析表

刪除表數(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ù)后并不會(huì)自動(dòng)釋放這些記錄占用的表空間,所以,即便表里面數(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)計(jì)單位由Byte轉(zhuǎn)為GB

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

重建索引

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

--重建非分區(qū)索引
ALTER TABLE your_table_index REBUILD [ONLINE] [NOLOGGING];

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

注意:

  • 設(shè)置日志級(jí)別為NOLOGGING 意味盡量減少日志,可以加速索引重建
  • ONLINENOLOGGING 兩者位置順序可以對(duì)調(diào),不影響
  • 普通情況下建立索引或者REBUILD索引時(shí),oracle會(huì)對(duì)基表加共享鎖,在這期間,無法對(duì)表進(jìn)行DML操作。如果希望避免這種情況,需要加ONLINE選項(xiàng)
  • 對(duì)索引進(jìn)行REBUILD時(shí),如果不加ONLINE選項(xiàng),則Oracle直接讀取原索引的數(shù)據(jù),否則直接掃描表中的數(shù)據(jù) ,索引在重建時(shí),查詢?nèi)匀豢梢允褂门f索引。實(shí)際上,Oracle在REBUILD索引的過程中,并不會(huì)刪除舊索引,直到新索引重建成功,這就是相對(duì)刪除索引然后重建索引的一個(gè)好處:不會(huì)影響原有的SQL查詢。但也正由于此,用REBUILD方式建立索引需要相應(yīng)表空間的空閑空間是刪除重建方式的2倍。
  • 不能直接REBUILD整個(gè)分區(qū)索引
    • 對(duì)于非組合索引,需要REBUILD每個(gè)分區(qū)(partition)
    • 對(duì)于組合索引,需要REBUILD每個(gè)子分區(qū)(subpartition)
    • 分區(qū)、子分區(qū)較多的情況下,可以使用下面的SQL可以生成相應(yīng)的REBUILD語(yǔ)句
--重建分區(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"; --注意,索引名稱必須大寫 

針對(duì)非分區(qū)索引,如果清理的表比較多,或者不知道被清理的表?yè)碛心男┧饕梢允褂靡韵耂QL查詢并生成對(duì)應(yīng)的重建索引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í)行計(jì)劃更加準(zhǔn)確,在一定程度上能帶來一些性能提升

ANALYZE TABLE table_name COMPUTE STATISTICS;

--等價(jià)于
ANALYZE TABLE table_name COMPUTE STATISTICS FOR TABLE FOR ALL INDEXES FOR ALL COLUMNS;

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

  • FOR TABLE的統(tǒng)計(jì)信息存在于視圖:USER_TABLES 、ALL_TABLESDBA_TABLES
  • FOR ALL INDEXES的統(tǒng)計(jì)信息存在于視圖: USER_INDEXES 、ALL_INDEXESDBA_INDEXES
  • FOR ALL COLUMNS的統(tǒng)計(jì)信息存在于試圖:USER_TAB_COLUMNSALL_TAB_COLUMNSDBA_TAB_COLUMNS

到此這篇關(guān)于Oracle 刪除大量表記錄操作分析總結(jié)的文章就介紹到這了,更多相關(guān)Oracle 刪除大量表 內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: Oracle
主站蜘蛛池模板: 竹山县| 祁东县| 双辽市| 敦化市| 锦州市| 嫩江县| 砀山县| 库伦旗| 自治县| 洞口县| 彭山县| 确山县| 尼玛县| 长宁县| 怀远县| 莱阳市| 民权县| 五大连池市| 漳浦县| 岚皋县| 南澳县| 凤翔县| 肇源县| 同仁县| 舒兰市| 惠州市| 德安县| 金阳县| 贺州市| 日照市| 英德市| 仙游县| 灌阳县| 咸宁市| 鸡东县| 黔江区| 衢州市| 泸西县| 将乐县| 博爱县| 佛学|