Home » RDBMS Server » Server Utilities » Evaluating PL/SQL Functions in sql loader control file
Evaluating PL/SQL Functions in sql loader control file [message #116107] Sun, 17 April 2005 17:00 Go to next message
narveer
Messages: 4
Registered: April 2005
Location: Dublin
Junior Member

Hi,

I have a csv data file and it has four columns. its of following format:

product desc,product type description,product type,product code.

I have a table which has four columns:
product id - integer NOT NULL
product type id - integer NOT NULL
product type - varchar2 NOT NULL
number - field for sorting NULL

I have to write a sql ldr script which has to:
1.Insert records in first three columns
2.Takes free format of the csv file in consideration
3. product desc in the csv file should be evaluated against pl/sql function func_product_id(return a number)
4. product type desc in the csv file should be evaluated against pl/sql function func_product_type(returns a number)
5. product type should be inserted as it is.
6. Ignore the fourth column in csv file

I have come up with following ctl file but its not working

LOAD DATA
INFILE data.csv
APPEND INTO TABLE XXX
FIELDS TERMINATED BY ','
( PRODUCT_ID EXPRESSION "func_product_id(:PRODUCT_ID)"
PRODUCT_TYPE_ID EXPRESSION "func_product_type(:PRODUCT_TYPE_ID)")
TEXT_VALUE)

If I dont use EXPRESSION then it says that the insert failed.
if I use EXPRESSION then it says that it cant bind the variables.

Can you guys please suggest whats wrong here?

How can i evaluate fields using pl/sql functions so that the evaluated value is stored in the table?


Thanks
Narveer
Re: Evaluating PL/SQL Functions in sql loader control file [message #116115 is a reply to message #116107] Sun, 17 April 2005 21:02 Go to previous messageGo to next message
Barbara Boehmer
Messages: 9102
Registered: November 2002
Location: California, USA
Senior Member
You are missing some commas and your parentheses don't match. Please see the corrected code below.

LOAD DATA
INFILE data.csv
APPEND INTO TABLE XXX
FIELDS TERMINATED BY ','
(PRODUCT_ID "func_product_id(:PRODUCT_ID)",
PRODUCT_TYPE_ID "func_product_type(:PRODUCT_TYPE_ID)",
PRODUCT_TYPE)
Re: Evaluating PL/SQL Functions in sql loader control file [message #116160 is a reply to message #116107] Mon, 18 April 2005 06:31 Go to previous messageGo to next message
narveer
Messages: 4
Registered: April 2005
Location: Dublin
Junior Member

Hi Barbara,

Many Many thanks for prompt reply. I tried your solution and I got following error:

Column Name Position Len Term Encl Datatype
------------------------------ ---------- ----- ---- ---- ---------------------
PRODUCT_ID FIRST * , CHARACTER
SQL string for column : "FUNC_PRODUCT_ID(:PRODUCT_ID)"
PROPERTY_ID NEXT * , CHARACTER
SQL string for column : "FUNC_PROPERTY_ID(:PROPERTY_ID)"
TEXT_VALUE NEXT * , CHARACTER

Record 1: Rejected - Error on table APP_PRODUCT_PROPERTY_VALUE.
ORA-01400: cannot insert NULL into ("PRS"."APP_PRODUCT_PROPERTY_VALUE"."PRODUCT_ID")

Record 2: Rejected - Error on table APP_PRODUCT_PROPERTY_VALUE.
ORA-01400: cannot insert NULL into ("PRS"."APP_PRODUCT_PROPERTY_VALUE"."PRODUCT_ID")

I guess here the Product_ID is evaluating to null.
Re: Evaluating PL/SQL Functions in sql loader control file [message #116177 is a reply to message #116107] Mon, 18 April 2005 08:08 Go to previous messageGo to next message
narveer
Messages: 4
Registered: April 2005
Location: Dublin
Junior Member

Hi Barbara,

I tried your solution and it worked. But it works only when I try to load only three columns in the csv file. If I include fourth column in csv file and try to load only the first three columns through sql loader then it goes on for hours and then i have interrupt it and stop the process.
Re: Evaluating PL/SQL Functions in sql loader control file [message #116370 is a reply to message #116177] Tue, 19 April 2005 13:01 Go to previous messageGo to next message
Barbara Boehmer
Messages: 9102
Registered: November 2002
Location: California, USA
Senior Member
Please see the demonstration below, which executes without any problems. If it does not solve your problem, then please provide what is different, such as sample data, control file, table structure, functions, and how you are loading. An actual copy and paste is preferable. You might try testing on a small sample of your data, then checking your log file. It may be that certain lines of your data result in an endless loop in one of your functions, or some such thing.

-- contents of data.csv:
1 prodcut desc,2 product type description,a,some product code,
5 prodcut desc,6 product type description,b,another product code,


-- contents of test.ctl:
LOAD DATA
INFILE data.csv
APPEND INTO TABLE xxx
FIELDS TERMINATED BY ','
(product_id      "func_product_id (:product_id)",
product_type_id "func_product_type (:product_type_id)",
product_type)


-- table:
scott@ORA92> CREATE TABLE xxx
  2    (product_id	INT	    NOT NULL,
  3  	product_type_id INT	    NOT NULL,
  4  	product_type	VARCHAR2(1) NOT NULL,
  5  	sort_field	NUMBER)
  6  /

Table created.


-- functions:
scott@ORA92> CREATE OR REPLACE FUNCTION func_product_id
  2    (p_product_id IN VARCHAR2)
  3    RETURN NUMBER
  4  AS
  5  BEGIN
  6    RETURN SUBSTR (p_product_id, 1, 1);
  7  END func_product_id;
  8  /

Function created.

scott@ORA92> SHOW ERRORS
No errors.
scott@ORA92> CREATE OR REPLACE FUNCTION func_product_type
  2    (p_product_type IN VARCHAR2)
  3    RETURN NUMBER
  4  AS
  5  BEGIN
  6    RETURN SUBSTR (p_product_type, 1, 1);
  7  END func_product_type;
  8  /

Function created.

scott@ORA92> SHOW ERRORS
No errors.


-- load data:
scott@ORA92> HOST SQLLDR scott/tiger CONTROL=test.ctl LOG=test.log


-- results:
scott@ORA92> SELECT * FROM xxx
  2  /

PRODUCT_ID PRODUCT_TYPE_ID P SORT_FIELD
---------- --------------- - ----------
         1               2 a
         5               6 b

scott@ORA92> 


Re: Evaluating PL/SQL Functions in sql loader control file [message #116380 is a reply to message #116370] Tue, 19 April 2005 14:32 Go to previous message
narveer
Messages: 4
Registered: April 2005
Location: Dublin
Junior Member

Hi Barbara,

Thanks for detailed solution. I have tried this approach and it works. Many Many thanks again.
Previous Topic: Importing Problem
Next Topic: SQLLOAD into 2 tables: Mater and Detail with same key
Goto Forum:
  


Current Time: Sun Jan 12 16:16:08 CST 2025