網(wǎng)站首頁 編程語言 正文
刪除表數(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會對基表加共享鎖,在這期間,無法對表進行DML操作。如果希望避免這種情況,需要加
ONLINE
選項 - 對索引進行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_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
原文鏈接:https://www.cnblogs.com/shouke/p/16706285.html
相關(guān)推薦
- 2022-05-23 Python+OpenCV實現(xiàn)在圖像上繪制矩形_python
- 2023-01-05 Python中使用jpype調(diào)用Jar包中的實現(xiàn)方法_python
- 2023-02-12 基于Redis驗證碼發(fā)送及校驗方案實現(xiàn)_Redis
- 2022-06-23 基于Flutter制作一個心碎動畫特效_Android
- 2022-09-20 Go?Redis客戶端使用的兩種對比_Golang
- 2022-10-06 Python中requests庫的基本概念與具體使用方法_python
- 2022-07-10 初識form表單中的兩種提交方式
- 2022-05-01 Python的裝飾器詳情介紹_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支