SQL Loader or external table with a trigger [message #593185] |
Wed, 14 August 2013 15:47 data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
data:image/s3,"s3://crabby-images/614f4/614f4cc59d75902b9bc81f9ac04b84b435304025" alt="" |
MitchM
Messages: 9 Registered: August 2013
|
Junior Member |
|
|
I have to have a sequence added to a large(288 million rows) file when I load the file into the table. If I use SQL Loader I can't use direct since I have a trigger for each row for the sequence but I am not sure if an external table will be any faster since the trigger will be firing for each row also. In this scenario is one better than the other ?
[Updated on: Wed, 14 August 2013 15:48] Report message to a moderator
|
|
|
|
|
|
|
|
Re: SQL Loader or external table with a trigger [message #593339 is a reply to message #593288] |
Thu, 15 August 2013 12:59 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
joy_division
Messages: 4963 Registered: February 2005 Location: East Coast USA
|
Senior Member |
|
|
MitchM wrote on Thu, 15 August 2013 10:29Joy- please explain how that would help
Use the trigger and ROWS=1. There is no buffer and the rows load one at a time (slowly) and the trigger executes for each one.
Unless I am just not understanding your problem, which can surely be the case.
|
|
|
Re: SQL Loader or external table with a trigger [message #593344 is a reply to message #593288] |
Thu, 15 August 2013 13:08 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
Lalit Kumar B
Messages: 3174 Registered: May 2013 Location: World Wide on the Web
|
Senior Member |
|
|
MitchM wrote on Thu, 15 August 2013 19:59
1. DIrect path to a staging table and then writing a procedure to load in the target table adding the sequence number
2.Use an external table and then load into target table adding the sequence number.
Why do you want to use a staging table, when you can skip it using pipelined function in any ETL process. Have a look at thisETL process
|
|
|
Re: SQL Loader or external table with a trigger [message #593353 is a reply to message #593344] |
Thu, 15 August 2013 14:31 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" |
data:image/s3,"s3://crabby-images/acc29/acc29ddc029daa9b975a87ffd5d807885f015c0d" alt="" |
Barbara Boehmer
Messages: 9104 Registered: November 2002 Location: California, USA
|
Senior Member |
|
|
If you use a SQL*Loader sequence, not a database sequence, then you can use the SQL*Loader direct path, and that will probably be your fastest method. Please see the simplified demonstration below.
SCOTT@orcl12c_11gR2> host type test.dat
ACCOUNTING|NEW YORK
RESEARCH|DALLAS
SALES|CHICAGO
OPERATIONS|BOSTON
SCOTT@orcl12c_11gR2> host type test.ctl
load data
into table dept2
fields terminated by '|'
trailing nullcols
(dname, loc, deptno sequence)
SCOTT@orcl12c_11gR2> create table dept2 as select * from dept where 1 = 2
2 /
Table created.
SCOTT@orcl12c_11gR2> select * from dept2
2 /
no rows selected
SCOTT@orcl12c_11gR2> host sqlldr scott/tiger control=test.ctl log=test.log direct=true
SQL*Loader: Release 12.1.0.1.0 - Production on Thu Aug 15 12:30:28 2013
Copyright (c) 1982, 2013, Oracle and/or its affiliates. All rights reserved.
Path used: Direct
Load completed - logical record count 4.
Table DEPT2:
4 Rows successfully loaded.
Check the log file:
test.log
for more information about the load.
SCOTT@orcl12c_11gR2> select * from dept2
2 /
DEPTNO DNAME LOC
---------- -------------- -------------
1 ACCOUNTING NEW YORK
2 RESEARCH DALLAS
3 SALES CHICAGO
4 OPERATIONS BOSTON
4 rows selected.
|
|
|