--oracle常用系统表
/*
dba_开头..... 
dba_users    数据库用户信息
dba_segments 表段信息
dba_extents   数据区信息
dba_objects   数据库对象信息
dba_tablespaces  数据库表空间信息
dba_data_files   数据文件设置信息
dba_temp_files  临时数据文件信息
dba_rollback_segs  回滚段信息
dba_ts_quotas  用户表空间配额信息
dba_free_space数据库空闲空间信息
dba_profiles  数据库用户资源限制信息
dba_sys_privs  用户的系统权限信息
dba_tab_privs用户具有的对象权限信息
dba_col_privs用户具有的列对象权限信息
dba_role_privs用户具有的角色信息
dba_audit_trail审计跟踪记录信息
dba_stmt_audit_opts审计设置信息
dba_audit_object  对象审计结果信息
dba_audit_session会话审计结果信息
dba_indexes用户模式的索引信息
user_开头
user_objects  用户对象信息
user_source  数据库用户的所有资源对象信息
user_segments  用户的表段信息
user_tables   用户的表对象信息
user_tab_columns  用户的表列信息
user_constraints  用户的对象约束信息
user_sys_privs  当前用户的系统权限信息
user_tab_privs  当前用户的对象权限信息
user_col_privs  当前用户的表列权限信息
user_role_privs  当前用户的角色权限信息
user_indexes  用户的索引信息
user_ind_columns用户的索引对应的表列信息
user_cons_columns  用户的约束对应的表列信息
user_clusters  用户的所有簇信息
user_clu_columns 用户的簇所包含的内容信息
user_cluster_hash_expressions   散列簇的信息
v$开头
v$database   数据库信息
v$datafile  数据文件信息
v$controlfile控制文件信息
v$logfile  重做日志信息
v$instance  数据库实例信息
v$log  日志组信息
v$loghist 日志历史信息
v$sga  数据库SGA信息
v$parameter 初始化参数信息
v$process  数据库服务器进程信息
v$bgprocess  数据库后台进程信息
v$controlfile_record_section  控制文件记载的各部分信息
v$thread  线程信息
v$datafile_header  数据文件头所记载的信息
v$archived_log归档日志信息
v$archive_dest  归档日志的设置信息
v$logmnr_contents  归档日志分析的DML DDL结果信息
v$logmnr_dictionary  日志分析的字典文件信息
v$logmnr_logs  日志分析的日志列表信息
v$tablespace  表空间信息
v$tempfile  临时文件信息
v$filestat  数据文件的I/O统计信息
v$undostat  Undo数据信息
v$rollname  在线回滚段信息
v$session  会话信息
v$transaction 事务信息
v$rollstat   回滚段统计信息
v$pwfile_users  特权用户信息
v$sqlarea    当前查询过的sql语句访问过的资源及相关的信息
v$sql         与v$sqlarea基本相同的相关信息
v$sysstat   数据库系统状态信息
all_开头
all_users  数据库所有用户的信息
all_objects  数据库所有的对象的信息
all_def_audit_opts  所有默认的审计设置信息
all_tables  所有的表对象信息
all_indexes所有的数据库对象索引的信息
session_开头
session_roles   会话的角色信息
session_privs   会话的权限信息
index_开头
index_stats  索引的设置和存储信息
伪表
dual  系统伪列表信息
*/
--删除表对象
select 'drop table '||segment_name from dba_segments where owner='VPMUSER' and segment_type='TABLE';
--创建表对象
select 
'create table '||segment_name || ' as select * from '||segment_name ||'@DBLINK' 
from dba_segments where owner='VPMUSER' and segment_type='TABLE';
检查表是否完整导入
select segment_name from dba_segments@aaa where owner='VPMUSER' and segment_type='TABLE'  
and (segment_name not like 'BIN$%'
and segment_name not like '%201%')
minus
select segment_name from dba_segments where owner='VPMUSER' and segment_type='TABLE'  and segment_name not like 'BIN$%'

如何加速Oracle大批量数据处理

一、提高DML操作的办法:

简单说来:

1、暂停索引,更新后恢复.避免在更新的过程中涉及到索引的重建.

2、批量更新,每更新一些记录后及时进行提交动作.避免大量占用回滚段和或临时表空间.

3、创建一临时的大的表空间用来应对这些更新动作.

4、批量更新,每更新一些记录后及时进行提交动作.避免大量占用回滚段和或临时表空间.

5、创建一临时的大的表空间用来应对这些更新动作.

6、加大排序缓冲区

alter session set sort_area_size=100000000;

insert into tableb select * from tablea;

commit;

如果UPDATE的是索引字段,就会涉及到索引的重建,暂停索引不会提高多少的速度,反而有可能降低UPDATE速度,

因为在更新是索引可以提高数据的查询速度,重建索引引起的速度降低影响不大。

ORACLE优化修改参数最多也只能把性能提高15%,大部分都是SQL语句的优化!

update总体来说比insert要慢 :

几点建议:

1、如果更新的数据量接近整个表,就不应该使用index而应该采用全表扫描

2、减少不必要的index,因为update表通常需要update index

3、如果你的服务器有多个cpu,采用parellel hint,可以大幅度的提高效率

另外,建表的参数非常重要,对于更新非常频繁的表,建议加大PCTFREE的值,以保证数据块中有足够的空间用于UPDATE, 从而降低CHAINED_ROWS。

二、各种批量DML操作:

(1)、oracle批量拷贝:

set arraysize 20

set copycommit 5000

copy from username/password@oraclename append table_name1

using select * from table_name2;

(2)、常规插入方式:

insert into t1 select * from t;

为了提高速度可以使用下面方法,来减少插入过程中产生的日志:

alter table t1 nologging;

insert into t1 select * from t;

commit;

(3)、CTAS方式:

create table t1

as

select * from t;

为了提高速度可以使用下面方法,来减少插入过程中产生的日志,并且可以制定并行度:

create table t1 nologging parallel(degree 2) as select * from t;

(4)、Direct-Path插入:

insert /*+append*/ into t1 select * from t;

commit;

为了提高速度可以使用下面方法,来减少插入过程中产生的日志:

alter table t1 nologging;

insert /*+append*/ into t1 select * from t;

Direct-Path插入特点:

1、 append只在insert … select …中起作用,像insert /*+ append */ into t values(…)这类的语句是不起作用的。在update、delete操作中,append也不起作用。

2、 Direct-Path会使数据库不记录直接路径导入的数据的重做日志,会对恢复带来麻烦。

3、 Direct-Path直接在表段的高水位线以上的空白数据块中写数据,不会重用高水位线以下的空间,会对空间的使用造成一定的浪费,对查询的性能也会造成一定的影响。而常规插入会优先考虑使用高水位线之下有空闲空间存在的数据块。因此理论上Direct-Path插入会比常规插入速度更快,因为Direct-Path直接使用新数据块,而常规插入要遍历freelist获取可用空闲数据块,如果同 nologging 配合,这种速度优势会更加明显。

4、 以append方式插入记录后,要执行commit,才能对表进行查询。否则会出现错误:ORA-12838: 无法在并行模式下修改之后读/修改对象。

5、 用append导入数据后,如果没有提交或者回滚,在其他会话中任何对该表的DML都会被阻塞(不会报错),但对该表的查询可以正常执行。

6、 在归档模式下,要把表设置为nologging,然后以append方式批量添加记录,才会显着减少redo数量。在非归档模式下,不必设置表的 nologging属性,即可减少redo数量。如果表上有索引,则append方式批量添加记录,不会减少索引上产生的redo数量,索引上的redo 数量可能比表的redo数量还要大。

7、 数据直接插入数据文件,绕过buffer cache并且忽略了引用完整性约束。

8、 不管表是否在nologging 下,只要是 direct  insert,就不会对数据内容生成undo。

9、 Oracle在Direct-Path INSERT 操作末尾,对具有索引的表执行索引维护,这样就避免了在drop掉索引后,再rebuild。

10、Direct-Path INSERT比常规的插入需要更多的空间。因为它将数据插入在高水位之上。并行插入非分区表需要更多的空间,因为它需要为每一个并行线程创建临时段。

11、在插入期间,数据库在表上获得排他锁,用户不能在表上执行并行插入、更新或者删除操作,并行的索引创建和build也不被允许。但却可以并行查询,但查询返回的是插入之前的结果集。

(5)、并行DML:

如果你的服务器有多个cpu,采用parellel hint,可以大幅度的提高效率

ALTER SESSION ENABLE PARALLEL DML;

INSERT /*+ PARALLEL(tableA, 2) */INTO tableA

SELECT * FROM tableB;

为了提高速度可以使用下面方法,来减少插入过程中产生的日志:

INSERT /*+ PARALLEL(tableA, 2) */INTO tableA NOLOGGING

SELECT * FROM tableB;

oracle默认并不会打开PDML,对DML语句必须手工启用。即需要执行

alter table enable parallel dml命令。

并行DML特点:

1、在并行DML模式中,默认的就是DIRECT-PATH插入,为了运行并行DML模式,必须满足以下条件:

a、必须是Oracle企业版;

b、必须在session中使并行DML生效,执行以下sql语句:

ALTER SESSION { ENABLE | FORCE } PARALLEL DML;

c、必须指定table的并行属性,在创建的时候或者其他时候,或者在insert操作时使用“PARALLEL”提示。

d、为了使Direct-Path Insert模式失效,在INSERT语句中指定“NOAPPEND”提示,覆盖并行DML模式。

2、并行Direct-Path INSERT到分区表:

类似于serial Direct-Path INSERT,每个并行操作分配给一个或者多个分区,每个并行操作插入数据到各自的分区段的高水位标志之上,commit之后,用户就能看到更新的数据。

3、并行Direct-Path INSERT到非分区表:

每个并行执行分配一个新的临时段,并插入数据到临时段。当commit运行后,并行执行协调者合并新的临时段到主表段,用户就能看到更新的数据。

4、Direct-Path INSERT可以使用Log或者不使用Log。

5、另外不得不说的是,并行不是一个可扩展的特性,只有在数据仓库或作为DBA等少数人的工具在批量数据操作时利于充分利用资源,而在OLTP环境下使用并行需要非常谨慎。事实上PDML还是有比较多的限制的,例如不支持触发器,引用约束,高级复制和分布式事务等特性,同时也会带来额外的空间占用,PDDL同 样是如此。

转载于:https://my.oschina.net/u/229524/blog/49105

ORACLE对表批处理操作相关推荐

  1. oracle批输入命令流,ORACLE对表批处理操作

    一.提高DML操作的办法: 简单说来: 1.暂停索引,更新后恢复.避免在更新的过程中涉及到索引的重建. 2.批量更新,每更新一些记录后及时进行提交动作.避免大量占用回滚段和或临时表空间. 3.创建一临 ...

  2. Oracle对表空间操作的sql

    管理员给用户增加不限制表空间权限 grant unlimited tablespace to 用户; 查看表空间使用情况 SELECT a.tablespace_name "表空间名&quo ...

  3. ORACLE对表的操作汇总

    1.创建表 语法1: CREATE TABLE 表名(字段名 数据类型 [[CONSTRAINT 约束名] 约束][DEFAULT 默认值],字段名 数据类型 [[CONSTRAINT 约束名] 约束 ...

  4. oracle大表如何快速删除一列,Oracle 对表中的记录进行大批量删除

    Oracle 对表中的记录进行大批量删除数量时,常常采用分批删除,逐次提交.其目的大概有三个原因: Oracle 对表中的记录进行大批量删除数量时,常常采用分批删除,逐次提交.其目的大概有三个原因: ...

  5. 请教怎么查询ORACLE的历史操作记录!

    请问如何查询ORACLE的历史操作记录!!!!! 我用的是linux oracle 11g r2,想查一下前几天的数据库的历史操作记录,例如对表的insert,delete,update等等的操作记录 ...

  6. oracle会闪,Oracle闪来操作

    Oracle闪回操作 Oracle闪回操作 1.记录当前时间或SCN 在数据库变动前记录时间或SCN SQL> select  to_char(sysdate,'YYYY-MM-DD HH24: ...

  7. oracle-DDL对表的操作

    在对表操作之前,一定要先了解基本数据类型: 常用的数据类型: Varchar2():表示字符串,一般保存长度比较小的内容(200以内建议使用,oracle独有,其他数据库为varchar) numbe ...

  8. Oracle 数据库常用操作语句大全

    原文:Oracle 数据库常用操作语句大全 一.Oracle数据库操作 1.创建数据库      create database databasename 2.删除数据库      drop data ...

  9. [oracle] Oracle存储过程里操作BLOB的字节数据的办法,例如写入32位整数

    作者: zyl910 一.缘由 BLOB是指二进制大对象,也就是英文Binary Large Object的缩写. 在很多时候,我们是通过其他编程语言(如Java)访问BLOB的字节数据,进行字节级的 ...

最新文章

  1. linux 系统安装配置 zabbix服务(源码安装)
  2. Collections.toMap 报错 空指针 key重复
  3. Linux ifconfig命令
  4. html搜索结果 重置,搜索结果和后退按钮/ HTML表格
  5. 微软再损一将!继Nat Friedman后,另一Xamarin联合创始人也已离职
  6. tomcat上的javaweb项目如何将ip地址更换为域名_Java Web 路线规划
  7. 新手学习Linux——搭建个人论坛
  8. css3 border-radius详解
  9. 网吧 电影服务器系统,XBS网吧电影系统10-26修改版(附教程)
  10. 荣耀20公测鸿蒙,荣耀 20、30 系列等机型,将开始逐步适配华为鸿蒙系统
  11. Android:动态使用权限(一)
  12. 白鹭引擎王泽:重度H5游戏性能优化技巧标题的文章
  13. 详细分析Win11与Win10哪个好用
  14. xml中处理大于号小于号的方法(Mybatis中大于、小于)
  15. [How-to] Screen命令的使用
  16. 一文教会你如何用 Python 分割合并大文件
  17. c语言与或非综合运用
  18. java输出1道100的数
  19. CS231n_1_assignment1_KNN做题笔记
  20. AUTOSAR工具ISOLAR简介

热门文章

  1. 匿名上位机V7波形显示教程
  2. mysql数据库熔断_服务熔断
  3. Windows自带MD5 SHA1 SHA256命令行工具
  4. VC运行库安装错误0x80240017解决过程
  5. NUC970 SD卡驱动(SDIO)
  6. 贴片电阻有哪几类封装尺寸?
  7. 朱清时——物理学步入禅境:缘起性空-(技术工作者上升到哲学思维)
  8. 计算机进入pe快捷键,U盘启动快捷键大全(附U盘启动必杀技)
  9. 华为设备IPsec简单配置
  10. 大数据分析原地踏步 原来是分析工具面临信任问题