Oracle sqlldr导入数据使用默认值和提高性能的方法

本文深入探讨了如何通过多种方法优化SQLLODR在导入大量数据时的性能,包括设置直接加载模式、调整读写缓冲区大小、增加绑定大小、使用并行加载等策略,以提升数据导入效率。

        在实际中常常有大量的数据需要导入到目前的数据库表中,oracle提供的sqlldr命令很好的meet了这个需求。在使用的过程中,我们发现,如果在数据库的table端的Column中设置default值,但是使用sqlldr就不会起作用,也就是默认值没有设置成功,所以需要设置默认值得时候,我们将默认值写到了ctl文件中。ctl文件如下:

Load data
infile 'd:\temp\buser.txt'  
Append
into table tmp_temp
TRAILING NULLCOLS
 (
phonenumber ,
addtime sysdate,
remark "suit"
)

     在导入大量数据的时候i,sqlldr往往不敬人意,在导入的时候存在效率问题,可以通过一下几种方式提高sqlldr的速度.

1. 使用direct=Y 这是速度提高最快的方式
2. 使用大的readsize/streamsize 提高读写数据的缓冲区的大小
readsize 的最大值为21971520(20M). streamszie的最大值不清楚,我自己一般设置为21971520
3. 使用大的bindsize (只对conventional path load有效) , 提高一次提交的数据量, 效果也比较明显.
4. 使用大的columnarrayrows . Oracle9i的最大值在750000-800000之间, 
Number of rows for direct path column array 提高direct load的效率, 
5. 使用并行load, 最好运行两个不同的sqlldr程序, 指定每个ctl文件加载不同的内容.
6. 先删除加载表上的索引和约束. 具体效果不是很清楚, 但是, 肯定可以提高加载的速度.
7. 最好将加载表设置成nologging/unrecoverable, 对于conventional path load比较有用, 减少重做日志的写入.
8. 加大date_cache的大小, 在加载表有日期字段的时候能够提高加载的速度.
date_cache -- size (in entries) of date conversion cache  (Default 1000)

<think>好的,我现在需要解决用户关于如何优化OracleSQL*Loader导入性能的问题。用户希望了解可以加快导入速度的参数配置,我需要根据提供的引用信息来整理有效的参数调整方法。首先,用户提供的引用中有提到几个关键参数:errors、rows、bindsize、readsize、PARALLEL等。我需要逐一分析这些参数的作用如何调整它们以提升性能。例如,rows参数控制每次提交的行数,增大这个值可以减少提交次数,从而提高效率。同样,bindsizereadsize影响缓冲区大小,更大的缓冲区可以减少I/O操作,加快数据加载速度。 接下来,引用中还提到了数据库层面的优化,比如调整SGA、PGA、共享池缓存大小。这些属于数据库服务器配置,需要SQL*Loader参数配合使用。例如,增大db_cache_size可以提高数据缓存能力,减少磁盘I/O,这对导入性能有帮助。然后,用户可能还需要知道如何并行处理数据。引用中的PARALLEL=TRUE说明可以启用并行加载,这能显著提升速度,尤其是在处理多个数据文件时。同时,关闭日志索引可能也是有效的优化手段,但需要权衡数据完整性恢复能力。 需要注意的是,用户可能没有意识到某些参数调整的风险,比如关闭错误处理或日志可能带来数据不一致的问题。因此,在建议这些优化方法时,需要提醒用户根据实际情况谨慎操作,并做好备份。 最后,整理步骤时应该分层次,先讲SQL*Loader本身的参数调整,再讲数据库配置,最后是其他辅助方法。同时,生成的相关问题需要覆盖性能分析、优化方法扩展应用场景,帮助用户全面了解。</think>### Oracle SQL*Loader 性能优化参数配置 #### 1. **核心参数优化** - **`ROWS`**: 控制每次提交的行数,默认值为64。增大该值可减少事务提交频率,例如设置为`ROWS=100000`[^4]。 $$ \text{公式示例:总提交次数} = \frac{\text{总数据量}}{\text{ROWS}} $$ - **`BINDSIZE`**: 指定单次提交的缓冲区大小(默认256KB),建议调整为与`ROWS`匹配的值,例如`BINDSIZE=20971520`(20MB)[^2][^4]。 - **`READSIZE`**: 控制读取数据文件的缓冲区大小,需与`BINDSIZE`一致或更大,例如`READSIZE=20971520`[^4]。 - **`DIRECT=TRUE`**: 启用直接路径加载,绕过数据库缓冲区,显著提升速度(需注意表空间锁定)[^3]。 - **`PARALLEL=TRUE`**: 启用并行加载,适用于多文件场景[^2]。 #### 2. **数据库服务器优化** - **调整SGA/PGA**:增大内存分配可减少磁盘I/O: ```sql ALTER SYSTEM SET sga_target=15G SCOPE=BOTH; ALTER SYSTEM SET pga_aggregate_target=5G SCOPE=BOTH; ```[^3] - **关闭表空间自动扩展**:避免频繁扩展影响性能: ```sql ALTER DATABASE DATAFILE 'path/to/datafile.dbf' AUTOEXTEND OFF; ```[^3] #### 3. **辅助优化方法** - **禁用索引约束**:导入前关闭索引约束,导入后重建: ```sql ALTER TABLE table_name DISABLE CONSTRAINT constraint_name; ALTER INDEX index_name UNUSABLE; ```[^3] - **减少日志生成**:使用`UNRECOVERABLE`选项跳过重做日志(仅限可容忍数据丢失的场景)[^3]。 --- ### 性能提升公式示例 $$ \text{总时间} = \frac{\text{数据量}}{\text{ROWS}} \times (\text{单次提交开销}) + \text{I/O延迟} $$ ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值