欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2022年09月26日 17:02:06   作者:授客  
這篇文章主要介紹了Oracle刪除大量表記錄操作分析總結(jié),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下

刪除表數(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轉(zhuǎn)為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];

注意:

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

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_TABLESDBA_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

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

相關(guān)文章

  • 如何解決Oracle EBS R12 - 以Excel查看輸出格式為“文本”的請求時亂碼

    如何解決Oracle EBS R12 - 以Excel查看輸出格式為“文本”的請求時亂碼

    這篇文章主要介紹了如何解決Oracle EBS R12 - 以Excel查看輸出格式為“文本”的請求時亂碼的相關(guān)資料,需要的朋友可以參考下
    2015-09-09
  • Oracle 臨時表空間SQL語句的實現(xiàn)

    Oracle 臨時表空間SQL語句的實現(xiàn)

    臨時表空間用來管理數(shù)據(jù)庫排序操作以及用于存儲臨時表、中間排序結(jié)果等臨時對象,本文主要介紹了Oracle 臨時表空間SQL語句的實現(xiàn),感興趣的可以了解一下
    2021-09-09
  • 解決Windows 7下安裝Oracle 11g相關(guān)問題的方法

    解決Windows 7下安裝Oracle 11g相關(guān)問題的方法

    本文將為大家介紹Windows 7下安裝Oracle 11g方面的有關(guān)問題解決方案。希望通過本文,能讓大家對11g這款產(chǎn)品有更多的認(rèn)識,需要的朋友可以參考下
    2015-08-08
  • Oralce 歸檔日志開啟與關(guān)閉示例

    Oralce 歸檔日志開啟與關(guān)閉示例

    本節(jié)主要介紹了Oralce 歸檔日志開啟與關(guān)閉、改變非歸檔模式到歸檔模式、改變歸檔模式到非歸檔模式,需要的朋友可以參考下
    2014-07-07
  • SQL中Charindex和Oracle中對應(yīng)的函數(shù)Instr對比

    SQL中Charindex和Oracle中對應(yīng)的函數(shù)Instr對比

    在項目中用到了Oracle中 Instr 這個函數(shù),順便仔細(xì)的再次學(xué)習(xí)了一下這個知識,使用 Instr 函數(shù)對某個字符串進(jìn)行判斷,判斷其是否含有指定的字符
    2013-10-10
  • 解決線上Oracle連接耗時過長的問題現(xiàn)象

    解決線上Oracle連接耗時過長的問題現(xiàn)象

    這篇文章主要介紹了記一次線上Oracle連接耗時過長的問題,本文通過問題定位分析給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • oracle行轉(zhuǎn)列與列轉(zhuǎn)行的幾種方式匯總

    oracle行轉(zhuǎn)列與列轉(zhuǎn)行的幾種方式匯總

    最近項目需要進(jìn)行行轉(zhuǎn)列,經(jīng)過上網(wǎng)查找到了一些解決方法,分享給大家,這篇文章主要給大家介紹了關(guān)于oracle行轉(zhuǎn)列與列轉(zhuǎn)行的幾種方式,文中通過圖文以及實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • oracle中的decode的使用介紹

    oracle中的decode的使用介紹

    這篇文章主要介紹了oracle中的decode函數(shù)的一些使用小技巧,需要的朋友可以參考下
    2013-09-09
  • 教你設(shè)計大型Oracle數(shù)據(jù)庫

    教你設(shè)計大型Oracle數(shù)據(jù)庫

    表及索引的存儲容量估算是根據(jù)其記錄長度及估算的最大記錄數(shù)確定的。在容量計算中考慮了數(shù)據(jù)塊的頭開銷及記錄和字段的頭開銷等等。表及索引的initial和next存儲參數(shù)一般設(shè)為相等,pctincrease設(shè)為0。
    2009-06-06
  • Oracle多表級聯(lián)更新詳解

    Oracle多表級聯(lián)更新詳解

    我們在平時的工作中可能遇到過,多表級聯(lián)更新,我也在網(wǎng)上看到過不少的方法,但是使用這些方法一般都沒成功過,所以今天我給大家介紹一種稍微麻煩的方法,有需要的朋友可以參考下
    2013-07-07

最新評論