Discussions
Categories
- 197K All Categories
- 2.5K Data
- 546 Big Data Appliance
- 1.9K Data Science
- 450.8K Databases
- 221.9K General Database Discussions
- 3.8K Java and JavaScript in the Database
- 31 Multilingual Engine
- 552 MySQL Community Space
- 479 NoSQL Database
- 7.9K Oracle Database Express Edition (XE)
- 3.1K ORDS, SODA & JSON in the Database
- 556 SQLcl
- 4K SQL Developer Data Modeler
- 187.2K SQL & PL/SQL
- 21.4K SQL Developer
- 296.3K Development
- 17 Developer Projects
- 139 Programming Languages
- 293K Development Tools
- 110 DevOps
- 3.1K QA/Testing
- 646.1K Java
- 28 Java Learning Subscription
- 37K Database Connectivity
- 158 Java Community Process
- 105 Java 25
- 22.1K Java APIs
- 138.2K Java Development Tools
- 165.3K Java EE (Java Enterprise Edition)
- 19 Java Essentials
- 162 Java 8 Questions
- 86K Java Programming
- 81 Java Puzzle Ball
- 65.1K New To Java
- 1.7K Training / Learning / Certification
- 13.8K Java HotSpot Virtual Machine
- 94.3K Java SE
- 13.8K Java Security
- 205 Java User Groups
- 24 JavaScript - Nashorn
- Programs
- 468 LiveLabs
- 39 Workshops
- 10.2K Software
- 6.7K Berkeley DB Family
- 3.5K JHeadstart
- 5.7K Other Languages
- 2.3K Chinese
- 175 Deutsche Oracle Community
- 1.1K Español
- 1.9K Japanese
- 233 Portuguese
i am new to pl/sql help me get to solve this error

the syntax for creating the HOME table and home details
create table home (F_NAME VARCHAR2(25),M_NAME VARCHAR2(25),C_NAME VARCHAR2(25));
create table home (F_NAME VARCHAR2(25),M_NAME VARCHAR2(25),C_NAME VARCHAR2(25));
the program for trigger
CREATE OR REPLACE TRIGGER HOME_BEFORE_DELETE
BEFORE INSERT
ON HOME
FOR EACH ROW
DECLARE
V_USERNAME VARCHAR2(25);
BEGIN
SELECT USER INTO V_USERNAME FROM DUAL;
INSERT INTO HOME_DETAILS
(F_NAME, M_NAME, C_NAME )
values
(:old.F_NAME,
:old.M_NAME,
:old.C_NAME ,V_USERNAME);
END
when executing it shows
ORA-24344: success with compilation error
Best Answer
-
Hi
Insertion to table home details is incorrect.You specified only 3 columns F_NAME, M_NAME, C_NAME in column list and gave 4 values in value list.Please correct it.
INSERT INTO HOME_DETAILS
(F_NAME, M_NAME, C_NAME )
values
(:old.F_NAME,
:old.M_NAME,
:old.C_NAME ,V_USERNAME);
Regards.
Manjusha
Answers
-
Hi
Insertion to table home details is incorrect.You specified only 3 columns F_NAME, M_NAME, C_NAME in column list and gave 4 values in value list.Please correct it.
INSERT INTO HOME_DETAILS
(F_NAME, M_NAME, C_NAME )
values
(:old.F_NAME,
:old.M_NAME,
:old.C_NAME ,V_USERNAME);
Regards.
Manjusha
-
[[email protected] ~]$ oerr ora 24344
24344, 00000, "success with compilation error"
// *Cause: A sql/plsql compilation error occurred.
// *Action: Return OCI_SUCCESS_WITH_INFO along with the error code
//
-
There are other issues with your trigger in addition to the column list discrepancy. You name the trigger HOME_BEFORE_DELETE, but define it as before insert. The old values that you reference in the trigger body are not available in a before insert trigger.
John
-
Your code should be like following:
Create tables:
create table home (F_NAME VARCHAR2(25),M_NAME VARCHAR2(25),C_NAME VARCHAR2(25));
create table home_details (F_NAME VARCHAR2(25),M_NAME VARCHAR2(25),C_NAME VARCHAR2(25),V_USERNAME varchar2(25));
Create Triggers:
CREATE OR REPLACE TRIGGER HOME_BEFORE_DELETE
BEFORE INSERT
ON HOME
FOR EACH ROW
DECLARE
V_USERNAME VARCHAR2(25);
BEGIN
SELECT USER INTO V_USERNAME FROM DUAL;
INSERT INTO HOME_DETAILS
(F_NAME, M_NAME, C_NAME,V_USERNAME )
values
(:new.F_NAME,
:new.M_NAME,
:new.C_NAME ,V_USERNAME);
END;
Test:
insert into home values('a','b','c');
commit;select * from home_details
Output:
a b c user1