国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

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

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

刪除表數據操作

清空所有表記錄:

TRUNCATE TABLE your_table_name;

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

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

釋放表空間

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

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

說明:sum(bytes)/(1024*1024) 數據統計單位由Byte轉為GB

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

重建索引

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

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

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

注意:

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

--重建分區索引-組合索引   
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"; --注意,索引名稱必須大寫 

針對非分區索引,如果清理的表比較多,或者不知道被清理的表擁有哪些索引,可以使用以下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的執行計劃更加準確,在一定程度上能帶來一些性能提升

ANALYZE TABLE table_name COMPUTE STATISTICS;

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

說明:生成的統計信息的存放位置:

  • FOR TABLE的統計信息存在于視圖:USER_TABLES 、ALL_TABLESDBA_TABLES
  • FOR ALL INDEXES的統計信息存在于視圖: USER_INDEXES 、ALL_INDEXESDBA_INDEXES
  • FOR ALL COLUMNS的統計信息存在于試圖:USER_TAB_COLUMNSALL_TAB_COLUMNSDBA_TAB_COLUMNS

到此這篇關于Oracle 刪除大量表記錄操作分析總結的文章就介紹到這了,更多相關Oracle 刪除大量表 內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: Oracle
主站蜘蛛池模板: 亚洲成人偷拍 | 午夜精品在线 | 欧美一级艳片视频免费观看 | 国内精品免费一区二区观看 | 九九精品视频在线 | 精品久久久久久久高清 | 欧美在线一区二区三区不卡 | 久久频这里精品99香蕉久网址 | 99久久亚洲综合精品网站 | 亚洲韩精品欧美一区二区三区 | 欧美一级欧美三级 | 特级片免费看 | 美国三级 | 国产精品李雅在线观看 | 99爱精品视频 | 久久久久爽亚洲精品 | 亚洲高清一区二区三区四区 | 亚洲欧美18v中文字幕高清 | 亚洲欧美日韩中文字幕在线一 | 国产成人免费福利网站 | 国产区二区 | 美女张开腿让人桶 | 欧美一做特黄毛片 | 成人在线亚洲 | 久久久久国产精品免费 | 一区二区三区成人 | 中文字幕一区二区在线播放 | 黑色丝袜美美女被躁视频 | 日韩免费高清一级毛片在线 | 欧美精品束缚一区二区三区 | 欧美一级看片免费观看视频在线 | 亚洲你我色| 国产综合精品久久久久成人影 | 国产手机在线小视频免费观看 | 69福利网 | 国产精品自在线 | 男女视频免费网站 | 一级做a爱片特黄在线观看免费看 | 欧美videofree性欧美另类 | 欧美成人激情在线 | 怡红院成人网 |