SQL & PL/SQL :: DDL Trigger After Alter Table
			Jul 22, 2010
				I created a DDL trigger which manipulates columns of a table after an "alter table" statement.
For us this was all the time 
"alter table XXX add NEW_COL varchar2(20)"
or 
"alter table XXX modify NEW_COL varchar2(20)".
Unfortunatly we have now a requirement which statements  "alter table XXX drop NEW_COL varchar2(20)".
My trigger works fine - you see no problem directly after statement execution but the table is then in an invalid status.
The connection will be destroyed after you tried to see the data of this table.
Also the export (creating a dump) will not work. 
The problem I see is that I the database will do a "modify" on a column which has internal the status "dropped".
How I can get the information what kind of alter table statement will be executed?
Or is there any chance to select only columns from USER_TAB_COLUMNS without the "dropped" flag?
create or replace trigger TRIGGER
  after alter
  on SCHEMA
declare
  vCharSet NLS_DATABASE_PARAMETERS.VALUE%TYPE;
begin
            -- Select all columns of a table
            select COLUMN_NAME, DATA_TYPE, DATA_LENGTH
            from   USER_TAB_COLUMNS
            where  TABLE_NAME = vTABLE_NAME; ...
            -- Loop for all columns from our select
            ...
                vSTATEMENT := 'alter table ' || vTABLE_NAME || ' modify ' || VOBJECTREC.COLUMN_NAME || ' ' || VOBJECTREC.DATA_TYPE || '(' || vNEW_DATA_LENGTH || ')';
--For example:
-- alter table XXX modify NEW_COL varchar2(20)
execute immediate vSTATEMENT;
    exception
           ...
end;
/
	
	View 11 Replies
  
    
		
ADVERTISEMENT
    	
    	
        Sep 20, 2011
        i need a trigger with alter commands to alter the table structure,it will be captured in a separate meta data table(META) 
CREATE OR REPLACE TRIGGER meta_alter AFTER Alter ON SCHEMA
BEGIN
 update meta set column_name=:new where table_name=ora_dict_obj_name column_name=:old;
END;
/
Meta table contains Table name and column name..i attached the table data in atext file
	View 39 Replies
    View Related
  
    
	
    	
    	
        Jun 19, 2013
        What is the difference between alter session and alter system?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Jul 26, 2011
        if  a user have alter table gant  but could not alter .. what additional grant it  need
SQL> alter table HRS_PERS_FIELDS_INC modify(PER0000252 NUMBER(19,3));
alter table HRS_PERS_FIELDS_INC modify(PER0000252 NUMBER(19,3))
*
ERROR at line 1:
ORA-00942: table or view does not exist
	View 11 Replies
    View Related
  
    
	
    	
    	
        May 4, 2011
        I have a table with usernames and passwords.  The passwords are stored in plaintext.  I would like to issue an ALTER command on the password field to store a hash instead, and then repopulate those fields with an encrypted version of the plaintext passwords that were there before.  
I would prefer to do this in a procedure, as I am going to perform it in a test environment first, then eventually in the production environment.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Apr 14, 2012
        I have a table PR in that some data is there for instance, My Mr_NO was Char(11) I modify MR_No to Char(13)My Table Structure now is:
MR_No Char(13),
Mr_Date Date
My Previous data is MR_NO=APN00209085
I want to add two 00 after alter the table I want my result data like APN0000209085.I am updating through this command 
update PR set Substr(MR_No,4,2)='00'
ERROR at line 1: ORA-00927: missing equal sign
Result I want is APN0000209085
	View 13 Replies
    View Related
  
    
	
    	
    	
        Mar 23, 2011
        I need to Modify the column(MSGID) data type from RAW to BLOB for a Queue Table, I'm getting the following error.
BANNER
---------------
Oracle Database 11g Enterprise Edition Release 11.2.0.2.0 - 64bit Production
PL/SQL Release 11.2.0.2.0 - Production
CORE11.2.0.2.0Production
YUV > 
YUV >  DESC PDA_REPORT_MESSAGE_QTAB
 Name       Null?Type
 ----------------------------------------------------- -------- ------------------------------------
 Q_NAME VARCHAR2(30)
 MSGID       NOT NULL RAW(16)
YUV > 
YUV > 
YUV > ALTER TABLE PDA_REPORT_MESSAGE_QTAB MODIFY (MSGID BLOB);
ALTER TABLE PDA_REPORT_MESSAGE_QTAB MODIFY (MSGID BLOB)
                                            *
ERROR at line 1:
ORA-22858: invalid alteration of datatype
YUV > 
YUV > 
YUV > 
YUV > 
YUV > ALTER TABLE PDA_REPORT_MESSAGE_QTAB ADD (MSGID_NEW BLOB);
ALTER TABLE PDA_REPORT_MESSAGE_QTAB ADD (MSGID_NEW BLOB)
*
ERROR at line 1:
ORA-24005: Inappropriate utilities used to perform DDL on AQ table PDADBA.PDA_REPORT_MESSAGE_QTAB
YUV > 
	View 10 Replies
    View Related
  
    
	
    	
    	
        Jun 11, 2009
        I want to alter a very large table.
ALTER TABLE MYTABLE ADD
(
ENTRY_TSTMP  DATE  DEFAULT SYSDATE NOT NULL
) 
My table is very large and I am getting an error saying I am out of undo space.  
The dba says the undo space is as big as the table.  
	View 1 Replies
    View Related
  
    
	
    	
    	
        Aug 3, 2010
        Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - 64bit Production
PL/SQL Release 11.1.0.6.0 - Production
"CORE 11.1.0.6.0 Production"
I altered existing table EVENT_SUB - added 3 columns. After that, I noticed all the procedures which had mention of this table name went in INVALID status, even if its simple SELECT, ALTER OR INSERT as shown below..
SELECT * FROM EVENT_SUB
OR 
INSERT INTO EVENT_SUB...
OR 
ALTER TABLE EVENT_SUB
WHERE....
So I had to recompile all the procedures associated with it. Is there any other ways to achieve this, like a line of code to add in the procedure itself, right after this DDL statements.
Sometimes i use this:
select object_name, object_type from all_objects where owner='TOYCOM' and status='INVALID'
Then, I would simply recompile the invalid objects.
For indexes, i do...
 
alter index <name> rebuild;
BTW, I did try to preview message, and then click on Create Topic, it gave me error..again.
"A system error has occurred.
	View 3 Replies
    View Related
  
    
	
    	
    	
        May 12, 2011
        I ran the following PL/SQL Code & I am getting the following Error: 
Drop table MODIFIEDTABLE
/
Commit
/
create table MODIFIEDTABLE(TABNAMES varchar2(100))
/
DECLARE
[code].....
RESULT:
Table dropped.
Commit complete.
Table created.
DECLARE
*
ERROR at line 1:
ORA-01735: invalid ALTER TABLE option 
ORA-06512: at line 12
	View 2 Replies
    View Related
  
    
	
    	
    	
        Nov 30, 2011
        how to play around with NDS dynamic sql and I'm trying to add a column on the fly.Basically the procedure is trying to take a table name, column name, and eventually a data type and adds it to a table.
It works fine without the bind variable for the column name, accepting the table name on the fly.As soon as it tries to use the column name I get an ORA-00904 invalid identifier exception.
Here is the procedure I'm using
CODEcreate or replace
procedure test(tbl_name varchar2, col_name varchar2) IS
qry varchar2(500);
begin
[code]....
Here is how I'm executing it.
CODEexecute test(tbl_name => 'BB_SHOPPER', col_name => 'MEMEBER');
	View 3 Replies
    View Related
  
    
	
    	
    	
        Sep 1, 2012
        SQL> ALTER SESSION SET CURRENT_SCHEMA = CLA_T3;
Session altered.
SQL> select sys_context('USERENV','SESSION_USER') current_user,
2 sys_context('USERENV','SESSION_SCHEMA') current_schema
3 from dual
4 ;
CURRENT_USER
--------------------------------------------------------------------------------
CURRENT_SCHEMA
--------------------------------------------------------------------------------
CSR_ETL
CLA_T3
SQL> set linesize 300;
SQL> /
CURRENT_USER
----------------------------------------------------------------------------------------------------
CURRENT_SCHEMA
----------------------------------------------------------------------------------------------------
CSR_ETL
CLA_T3
SQL> create table cla_t3.test (r number, b char(2));
create table cla_t3.test (r number, b char(2))
*
ERROR at line 1:
ORA-01031: insufficient privileges
SQL> create table test (r number, b char(2));
create table test (r number, b char(2))
*
ERROR at line 1:
ORA-01031: insufficient privileges
After Setting current schema to 'CLA_T3', I am unable to create table in cla_t3 schema.
	View 5 Replies
    View Related
  
    
	
    	
    	
        Oct 18, 2012
        alter index test_idx1 shrink space; 
I've heard that this statement causes a table lock but cant find any information on this.if it is so, is it a write lock or also a read lock of the table?
	View 5 Replies
    View Related
  
    
	
    	
    	
        Mar 11, 2011
        We have some tables in our database in which for loading data we have the setup in place to do Exchange partition after data load into staging. Today we did changes to column length to one pair of main and staging table. Post that Exchange partition stop working.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Aug 11, 2010
        can you use alter table command to disable/enable constraints in a form if you can how, if you cant why
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jun 19, 2012
        Can i alter the table to create partition on non partition table, i have tried and could not create it. Do we have some other means to do it as this is the live table and cannot drop them else will lose the data.
	View 1 Replies
    View Related
  
    
	
    	
    	
        May 30, 2012
        I need to import some data from .csv files. There is one file each day, so I want them to be automatically imported into the DB. This is the format it comes in:
DSM,LOD,20120524,01,01,9999AMP02,1.1262240,M,0.6397380,M
DSM,LOD,20120524,01,02,9999AMP02,1.1315700,M,0.6450840,M
DSM,LOD,20120524,01,03,9999AMP02,1.1297880,M,0.6450840,M
I want this data to go into TEMP_TABLE. It then needs to reformatted as it goes from temp_table to my_table:
filename,readingID, field1,field2,date,num1,num2,meterid,read1,m1,read2,m2
so filename is the actual name of the .csv file that this row came from. And reading id is date, num1, num2, meterid combined. And the remaining fields coming from temp_table
This is what I have:
procedure import_data()
begin
  TEMPFILENAME CHAR(60)='DSM_2010_Husky_Oil_20120525064122_20120525065011.csv';
  create table temp_table
  (dsm char(3),lod char(3),usage_date date,he char(2),reading char(2),loc_id char(9),mwh number(15,10),eormmwh char(1),mvar number(15,10),eormmvar char(1));
[code]....
, which does not work at all.
	View 2 Replies
    View Related
  
    
	
    	
    	
        Aug 2, 2012
        I have table t1 and t1 , I want a procedure that will insert all records from t1 into table t2 and after successfull insert table t1 should be truncated .
If their is any problem in insert in to table t2 , the truncate command should not work .
Truncate command should work only after successfully insert command .
	View 3 Replies
    View Related
  
    
	
    	
    	
        Aug 28, 2011
        My problem is the following:
At the time when P_delivery_date changes in P_ORDERS I want to transfer P_delivery_date to S_delivery_date in S_ORDERS for corresponding records.
Tables:
 purchase orders table P_ORDERS: 
 P_order_number,
 P_poz_number, 
 S_order_number, 
 S_poz_number, 
 P_delivery_date
 
 sales orders table S_ORDERS: 
 S_order_number, 
 S_poz_number, 
 S_delivery_date
 My question is:
 Is it possible and what would be the solution using the TRIGGER on table P_ORDERS to update S_delivery_date with P_delivery_date in S_ORDERS?
	View 2 Replies
    View Related
  
    
	
    	
    	
        Oct 20, 2011
        Oracle 11.2 - The goal is to create a trigger on table and anytime an update, delete or insert is done on the table, write values to a second table. I have the trigger and it works except it is not loading my col1/PK values. I understand I need to do a new/old value. Col1 is my PK on Table that I want to load anytime there is an update/delete/insert on the table. How do I code the old/new variable?
My 
CREATE OR REPLACE TRIGGER TRIGGER_NAME
   AFTER INSERT OR UPDATE OR DELETE
   ON TABLE_NAME
   FOR EACH ROW
DECLARE
   v_col1   TABLE_NAME.COLUMN%TYPE;
BEGIN
[code]...  
	View 5 Replies
    View Related
  
    
	
    	
    	
        Nov 24, 2011
        CREATE or REPLACE TRIGGER Emp_Ins_Upd_Del_Trig
BEFORE delete or insert or update on EMP
FOR EACH ROW
BEGIN
if UPDATING then
[Code] .....
	View 2 Replies
    View Related
  
    
	
    	
    	
        Nov 24, 2010
        I am ceating a trigger to...when I update or insert a record in table and if salary of that record is less than 1600 than it should be updated to 2000. My trigger is
CREATE or REPLACE TRIGGER myTrigger
BEFORE UPDATE OR INSERT ON newemp
FOR EACH ROW
BEGIN
[code]...
There are no errors with trigger while compiling, but when I update or insert a record, it does not update the table. It looks like the trigger is being ignored.
	View 2 Replies
    View Related
  
    
	
    	
    	
        May 4, 2011
        i want to write, just ONE trigger that handles all DMS events at schema level and writes the field changes to a specific log table. i wanna to write like 'FOR EACH FIELD' as for each row (& also each table). it turns in the fields section and if the 'old' and 'new' values isnt same, it triggers this function & writes changes to log.
ex. is like:
FOR EACH ROW
FOR EACH FIELD 
if (old.value != new.value)
insert into LOG(..., old.name,new.name) values (..., old.value, new.value)
NEXT // FIELD
NEXT // ROW
	View 19 Replies
    View Related
  
    
	
    	
    	
        Feb 1, 2013
        Is it possible to create table using trigger?
I tried but failed...
CREATE OR REPLACE TRIGGER tri1
AFTER UPDATE
ON dept
FOR EACH ROW   
declare
pragma AUTONOMOUS_TRANSACTION;   
BEGIN
execute immediate 'create table dept_dum as select  * from dept';     
END;
/
SQL> update dept set deptno=23 where deptno=10;
update dept set deptno=23 where deptno=10
       *
ERROR at line 1:
ORA-01031: insufficient privileges
ORA-06512: at "SCOTT.TRI1", line 6
ORA-04088: error during execution of trigger 'SCOTT.TRI1'
I am running this as scott user
My requirement is to 
create table as select * from table_name where flag=1
This has to be done parallel for all the tables for which this flag is enabled and by that trigger delete all those rows which were backed up as table.
	View 4 Replies
    View Related
  
    
	
    	
    	
        Jan 4, 2007
        Having trouble creating a trigger to populate another table.
The SQL:
CREATE OR REPLACE TRIGGER "P_M_YES"
AFTER INSERT OR UPDATE ON DOMAIN
REFERENCING NEW AS NEW.P_M AND OLD AS OLD.P_M      
FOR EACH ROW
    WHEN (NEW.P_M = YES)
    BEGIN
        INSERT INTO PAGE_MAKER VALUES(:NEW.D_NAME, :NEW.USER_ID);
    END P_M_YES;
/
ALTER TRIGGER  "P_M_YES" ENABLE
/
I get an invalid trigger specification.
	View 3 Replies
    View Related
  
    
	
    	
    	
        Mar 12, 2012
        I have looked at the code you pointed me to, and have attempted to get it to work using a package, but I cant even get the package to compile..
CREATE OR REPLACE PACKAGE BODY trigger_api AS
PROCEDURE tab1_row_change (p_numass     IN  varchar2,
                           p_datcre  IN  date) IS
BEGIN
  INSERT INTO tempjob (numass, datecre) VALUES (p_numass, p_datcre);
END tab1_row_change;
[code]....
Doing this process from code is not an option and MUST happen automatically via triggers.The mutating trigger error can sometimes be avoided: URL....
	View 1 Replies
    View Related
  
    
	
    	
    	
        Mar 9, 2012
        I am trying to create a trigger which does the following : A flag in the initial able is set to Y. When this happens, the record needs to be inserted into a history table and then DELETED from the calling table.
It must happen in triggers, but I keep getting the mutating error.I have tried to use a Compound trigger, but with no luck and just dont really understand how to get this to work.
Doing this process from code is not an option and MUST happen automatically via triggers.
	View 1 Replies
    View Related
  
    
	
    	
    	
        Aug 20, 2012
        We are running an Oracle 10g server.
We are adding support for barcode scanner in one part of our information system. So that the mechanics can add parts to an work orders bill of material themselves using barcode scanner to scan the part and enter the qty.
I can via SQL add a part to the bill of materials and reserve the part. But then the part needs to be issued to make it disappear from the stock.
I have found a table that contains information about the part and the bill of material, it has a column named "QTY ISSUED" I have tried via an update command to set the qty issued = 1 for the reserved part. The table is updated, and via SQL everything looks fine, but the part doesn't disappear from the stock. So my guess is that there is a trigger or function somewhere that I need for this.
	View 13 Replies
    View Related
  
    
	
    	
    	
        Mar 30, 2010
        I am trying to create some PL/SQL that will create a trigger for UPDATES and INSERTS which will update a column on the same row to the system date.
So far I have:
DECLARE 
tablename VARCHAR(30) := 'table';
triggername VARCHAR(30) := 'mytrigger_' || tablename;
[Code]....
I have declared the tablename and triggername outside the trigger creation as I need this to be parameterised for a list of tables.
The procedure IsCDCUser just checks it should be updating for this user.
The problem I get is the following error:
Bind Variable "NEW" is NOT DECLARED
	View 3 Replies
    View Related
  
    
	
    	
    	
        Apr 17, 2012
        I have to write a trigger on a table which contain lot of parameters.But i need to pick a specific row and check that without disturbing other stuffs.Is there a way to write Before update trigger on a particular rows filtering the unneccasary rows.
The requirement is when user update the date from front end (Java application) the trigger should check the date and validate that it should be month end date. For example.
1)04/21/2012  wrong date
2)04/30/2012 correct date
3)03/29/2012 Wrong date
4)03/31/2012 correct date
	View 7 Replies
    View Related