亚洲精品二区三区_91手机在线播放_91国内视频在线观看_91在线免费播放视频_国产精品九一_久久久国产亚洲精品

廊坊新闻网-主流媒体,廊坊城市门户

Oracle 删除大量表记录操作总结

2023-09-09 11:45:07 来源:中年农码工

删除表数据操作


(资料图片仅供参考)

清空所有表记录

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 意味尽量减少日志,可以加速索引重建 ONLINE , NOLOGGING 两者位置顺序可以对调,不影响 普通情况下建立索引或者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_TABLES 、 DBA_TABLES FOR ALL INDEXES 的统计信息存在于视图: USER_INDEXES 、 ALL_INDEXES 、 DBA_INDEXES FOR ALL COLUMNS 的统计信息存在于试图: USER_TAB_COLUMNS 、 ALL_TAB_COLUMNS 、 DBA_TAB_COLUMNS

关键词:

主站蜘蛛池模板: 亚洲成av人片乱码色午夜 | 99热这里只有精品国产99 | 欧美特黄级乱色毛片 | 亚洲最大av一区二区三区 | 狠狠狠狠狠狠狠狠 | 欧美亚洲色帝国 | 国产精品亚洲色图 | 日韩中文字幕免费 | 亚洲精品欧洲久久婷婷99 | 国产一级做a爱免费观看 | 蜜臀aⅴ国产精品久久久国产老师 | 大陆极品少妇内射aaaaa | 国产欧美日韩综合 | 亚洲成成品网站源码中国有限公司 | 国内精品一区二区 | 一本色道久久88加勒比—综合 | 色屁屁影视大全 | 亚洲精品人成在线观看 | 久久国产免费观看精品 | 色综合久久综合网观看 | 玩50岁四川熟女大白屁股直播 | 欧美亚洲国产一区二区三区 | 中文字幕天天躁日日躁狠狠躁免费 | 亚洲国产成人精品女人久久久 | 国产大尺度福利视频在线观看 | 午夜在线视频免费 | 国产精品无码久久综合 | 中文字幕av伊人av无码av | 99草草国产熟女视频在线 | 午夜污片 | 国产台湾无码av片在线观看 | 黑人大战中国av女叫惨了 | 日韩精品无码免费专区网站 | 永久免费无码av网站在线观看 | 色婷婷色综合 | 熟妇人妻系列aⅴ无码专区友真希 | 天天夜碰日日摸日日澡性色av | 精品国产成人一区二区 | 91国内精品久久久久免费影院 | 少妇愉情理伦片高潮日本 | 久久久精品一区 |