1) Create an error table to capture the errors from Insert, Update and Delete. To create this table,use Oracle's built in create_error_log function
Exec dbms_errlog.create_error_log("SOURCE_TABLE")
SOURCE_TABLE: Replace SOURCE_TABLE with name of your table. By default, error table will be prefixed by "ERR$_"
If you want to create a error table with a different name,
Exec dbms_errlog.create_error_log("SOURCE_TABLE","ERROR_TABLE_NAME")
By Default Error table will contain all columns from source table.
If your source_table contains long or blob columns, you need to skip them in the error table
Exec dbms_errlog.create_error_log("SOURCE_TABLE", skip_unsupported =>true)
Example: Insert into table_name ( col1,col2....) Values (Col1,Col2....)
log errors into err$_table_name
reject limit unlimited;
Update table_name
Set Col1 = ....
Where.....
log errors into err$_table_name
reject limit unlimited;
Delete table_name
Where.....
log errors into err$_table_name
reject limit unlimited;
If you don't use reject limit unlimited your transaction will fail and only 1 record will be inserted in the err$ table.
25 August 2008
19 August 2008
Oracle: How to convert CLOB to BLOB
CREATE OR REPLACE Procedure Convert_Clob_To_Blob( clobvalue in clob , blobValue in out blob)
as
Position pls_integer := 1;
Temp_Buffer raw(32767);
Length_To_Copy int ;
clob_Length pls_integer := dbms_lob.getLength(clobValue);
begin
dbms_lob.open(BlobValue,dbms_lob.lob_readwrite);
--Length_To_Copy := least(1000,(clob_Length - Position) + 1);
While (Position <= clob_Length ) loop
Length_To_Copy := least(1000,(clob_Length - Position) + 1);
Temp_Buffer := utl_raw.cast_to_raw(dbms_lob.substr(clobValue,Length_To_Copy,Position));
If utl_raw.length(Temp_Buffer) > 0 then
dbms_lob.writeappend(BlobValue,utl_raw.length(Temp_Buffer),Temp_Buffer);
end if;
Position := Position + Length_To_Copy;
--Length_To_Copy := least(1000,(clob_Length - Position) + 1);
end loop;
dbms_lob.close(BlobValue);
end;
/
In order to test the above code look at this example.Lets assume you have a table called TABLE_NAME with a clob column called CLOB_COLUMN
Declare
b blob;
Begin
For cTemp in ( Select clob_column from table_name ) loop
Begin
b := null;
Insert into TABLE_NAME2(BLOB_COLUMN) values (empty_blob())
returning BLOB_COLUMN into b;
Convert_Clob_To_Blob (cTemp.clob_column,b);
end;
end loop;
Commit;
end;
/
14 August 2008
Oracle: How to retrieve DDL of any object
Select dbms_metadata.get_ddl('TABLE','TABLE_NAME') from dual
Some key parameters for get_ddl
object_type - The type of object to be retrieved. ex: TABLE, TABLESPACE,INDEX etc
object_name - Name of the object.
object_schema- Schema containing the object. Defaults to the caller's schema.
ex: Select dbms_metadata.get_ddl ('TABLE','EMPLOYEE','SCOTT') from dual
Some key parameters for get_ddl
object_type - The type of object to be retrieved. ex: TABLE, TABLESPACE,INDEX etc
object_name - Name of the object.
object_schema- Schema containing the object. Defaults to the caller's schema.
ex: Select dbms_metadata.get_ddl ('TABLE','EMPLOYEE','SCOTT') from dual
12 August 2008
11 August 2008
Toad: Debug menu grayed out (cannot debug any procedure)
Even if you have Toad XPert Edition or Toad with DBA Module, I sometime find the debug menu grayed out. Even If I create a new proceudre, It's still grayed out. If you get this issue, try the following and reconnect.
Issue Debug Connect Sesstion to your user as SYS or System.
Grant DEBUG CONNECT SESSION TO schema_owner
Replace Schema_Owner with your user name.
Log out and Log back in, Now Toad Debug menu will be available.
Another workaround is to give DBA Privs which is not recommended.
Issue Debug Connect Sesstion to your user as SYS or System.
Grant DEBUG CONNECT SESSION TO schema_owner
Replace Schema_Owner with your user name.
Log out and Log back in, Now Toad Debug menu will be available.
Another workaround is to give DBA Privs which is not recommended.
08 August 2008
06 August 2008
Oracle: How to generate N sequential numbers
How to generate N sequential numbers using sql
select level from
dual
connect by level < N
Replace N by whatever number you want.
select level from dual connect by level <> 50
select level from
dual
connect by level < N
Replace N by whatever number you want.
select level from dual connect by level <> 50
LDAP: In a nutshell
LDAP Lightweight Directory Access Protocol (Based on X 500 Standard)
LDAP --> Protocol to retrieve data stored in information directory, which is heavily optimized for read performance.
LDAP --> Allows you to securely delegate read and modification authority based on your specific needs using ACIs (collectively, an ACL, or Access Control List).
LDAP --> Tree Structure
Top level node called base DN (Distinguished Name)
Base DN in one of the 3 formats (for foobar company in US)
o="company name",c=Country
ex: o="foobar,Inc", c=US
(not preferred now a days,as no place to put website name)
o="website of the company"
ex: o=foobar.com (most common as straight forward)
dc=compnay, dc = com
ex: dc=foobar,dc=com
(used nowadays, Microsoft Acive Directory uses this format)
Here o=>organisation, c=>country,dc=>domain components
Under root base DN, Create nodes that logically seperate your data.
For Historic reasons (X500),These logical components are set up as OU,CN
OU=>Origanizational Unit
CN=>Common Name
All entires in LDAP have a unique DN and this DN is composed of 2 parts, RDN(Relative) and lcoation within the ldap direcotry where the record resides.
RDN is the portion of your DN that is not related to the directory tree structure.
Most entries stored in ldap will have a name, they are stored as CN
Most objects stored in LDAP will use CN value as RDN
So, If I want to store recipie for Oatmeal raisin
ex:
dc=foobar, dc=com
- ou=recipie
-- cn=oatmeal raisin
So, the full DN for the LDAP record is (Remeber it read it backwards) cn=oatmeal raisin,ou=recipie,dc=foobar,dc=com
Typically to store employee logins either CN is used store their name or UID is used to store the login
ex: dc=abclondon,dc=com
-ou=london
--cn="ramesh manni" or uid="rmanni" ----> name-based or login-based
LDAP stores all information for a given record as key-value pairs
ex:
dn: cn=Oatmeal Deluxe, ou=recipes, dc=foobar, dc=com
cn: Instant Oatmeal Deluxe
recipeCuisine: breakfast
recipeIngredient: 1 packet instant oatmeal
recipeIngredient: 1 cup water
recipeIngredient: 1 pinch salt
recipeIngredient: 1 tsp brown sugar
recipeIngredient: 1/4 apple, any type
Searches against these attribute/value pairs are case insensitive excpet for passwords
LDAP --> Protocol to retrieve data stored in information directory, which is heavily optimized for read performance.
LDAP --> Allows you to securely delegate read and modification authority based on your specific needs using ACIs (collectively, an ACL, or Access Control List).
LDAP --> Tree Structure
Top level node called base DN (Distinguished Name)
Base DN in one of the 3 formats (for foobar company in US)
o="company name",c=Country
ex: o="foobar,Inc", c=US
(not preferred now a days,as no place to put website name)
o="website of the company"
ex: o=foobar.com (most common as straight forward)
dc=compnay, dc = com
ex: dc=foobar,dc=com
(used nowadays, Microsoft Acive Directory uses this format)
Here o=>organisation, c=>country,dc=>domain components
Under root base DN, Create nodes that logically seperate your data.
For Historic reasons (X500),These logical components are set up as OU,CN
OU=>Origanizational Unit
CN=>Common Name
All entires in LDAP have a unique DN and this DN is composed of 2 parts, RDN(Relative) and lcoation within the ldap direcotry where the record resides.
RDN is the portion of your DN that is not related to the directory tree structure.
Most entries stored in ldap will have a name, they are stored as CN
Most objects stored in LDAP will use CN value as RDN
So, If I want to store recipie for Oatmeal raisin
ex:
dc=foobar, dc=com
- ou=recipie
-- cn=oatmeal raisin
So, the full DN for the LDAP record is (Remeber it read it backwards) cn=oatmeal raisin,ou=recipie,dc=foobar,dc=com
Typically to store employee logins either CN is used store their name or UID is used to store the login
ex: dc=abclondon,dc=com
-ou=london
--cn="ramesh manni" or uid="rmanni" ----> name-based or login-based
LDAP stores all information for a given record as key-value pairs
ex:
dn: cn=Oatmeal Deluxe, ou=recipes, dc=foobar, dc=com
cn: Instant Oatmeal Deluxe
recipeCuisine: breakfast
recipeIngredient: 1 packet instant oatmeal
recipeIngredient: 1 cup water
recipeIngredient: 1 pinch salt
recipeIngredient: 1 tsp brown sugar
recipeIngredient: 1/4 apple, any type
Searches against these attribute/value pairs are case insensitive excpet for passwords
04 August 2008
Oracle: Regular Expression: Examples
How to split strings like "ABC Company (XXX)" into "ABC Company", "XXX"
Select col1, regexp_substr(col1,'[^(]*') Comp_Name,
ltrim(regexp_substr(col1,'\([^)]*'),'(') comp_code
from ( Select 'ABC Company (XXX)' col1 from dual ).
Script does 3 things
1) For name, It takes everything till it hits '('
2) For Code, it takes everything from '(' [you need to escape open paranthesis symbol], till it finds the closing parenthesis ')'.
3) Ltrim is to remove the Open parenthesis in the code.
Select col1, regexp_substr(col1,'[^(]*') Comp_Name,
ltrim(regexp_substr(col1,'\([^)]*'),'(') comp_code
from ( Select 'ABC Company (XXX)' col1 from dual ).
Script does 3 things
1) For name, It takes everything till it hits '('
2) For Code, it takes everything from '(' [you need to escape open paranthesis symbol], till it finds the closing parenthesis ')'.
3) Ltrim is to remove the Open parenthesis in the code.
Regular Expression: How to split comma seperated values using sql
Lets create a table first and insert few comma seperated rows.
1) create table tab1 (owner number, cars varchar2(200));
2) insert into tab1 (
select 1, 'Ford,Toyota,Nissan' from dual union all
select 2, 'Lexus,Mercedes,BMW,Infiniti' from dual union all
select 3, 'Ferrari' from dual union all
select 4, 'Porsche,Lotus,Lamborghini,Maserati,Aston Martin' from dual union all
select 5, 'Maybach,Bentley' from dual);
3) select owner, cars str from tab1;
Now here is the sql to split.
select owner, car
from ( select owner, regexp_substr(str, '[^,]+', 1, level) car,
level lv, lag(level, 1, 0) over (partition by owner order by level) lg
from ( select owner, cars str from tab1 )
connect by regexp_substr(str, '[^,]+', 1, level) is not null
)
where lv != lg;
Replace"," in [^,] with your delimiter
1) create table tab1 (owner number, cars varchar2(200));
2) insert into tab1 (
select 1, 'Ford,Toyota,Nissan' from dual union all
select 2, 'Lexus,Mercedes,BMW,Infiniti' from dual union all
select 3, 'Ferrari' from dual union all
select 4, 'Porsche,Lotus,Lamborghini,Maserati,Aston Martin' from dual union all
select 5, 'Maybach,Bentley' from dual);
3) select owner, cars str from tab1;
Now here is the sql to split.
select owner, car
from ( select owner, regexp_substr(str, '[^,]+', 1, level) car,
level lv, lag(level, 1, 0) over (partition by owner order by level) lg
from ( select owner, cars str from tab1 )
connect by regexp_substr(str, '[^,]+', 1, level) is not null
)
where lv != lg;
Replace"," in [^,] with your delimiter
Subscribe to:
Posts (Atom)