Discussions
Categories
- 385.5K All Categories
- 4.9K Data
- 2.5K Big Data Appliance
- 2.4K Data Science
- 453.4K Databases
- 223.2K General Database Discussions
- 3.8K Java and JavaScript in the Database
- 47 Multilingual Engine
- 606 MySQL Community Space
- 486 NoSQL Database
- 7.9K Oracle Database Express Edition (XE)
- 3.2K ORDS, SODA & JSON in the Database
- 585 SQLcl
- 4K SQL Developer Data Modeler
- 188K SQL & PL/SQL
- 21.5K SQL Developer
- 46 Data Integration
- 46 GoldenGate
- 298.4K Development
- 4 Application Development
- 20 Developer Projects
- 166 Programming Languages
- 295K Development Tools
- 150 DevOps
- 3.1K QA/Testing
- 646.7K Java
- 37 Java Learning Subscription
- 37.1K Database Connectivity
- 201 Java Community Process
- 108 Java 25
- 22.2K Java APIs
- 138.3K Java Development Tools
- 165.4K Java EE (Java Enterprise Edition)
- 22 Java Essentials
- 176 Java 8 Questions
- 86K Java Programming
- 82 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
- 208 Java User Groups
- 25 JavaScript - Nashorn
- Programs
- 667 LiveLabs
- 41 Workshops
- 10.3K Software
- 6.7K Berkeley DB Family
- 3.6K JHeadstart
- 6K Other Languages
- 2.3K Chinese
- 207 Deutsche Oracle Community
- 1.1K Español
- 1.9K Japanese
- 474 Portuguese
Getting ORA-00920: invalid relational operator For Merge Statement

Hi All,
I am getting the ORA-00920: invalid relational operator message foe the below query. Please help on this.
MERGE INTO PS_CT_IQN_ACC_STG STG USING PS_CTS_IQN_BU_RATE RT ON (STG.BUSINESS_UNIT = RT.BUSINESS_UNIT)
WHEN MATCHED THEN
UPDATE
SET STG.STANDARD_RATE = RT.STANDARD_RATE,
STG.STANDARD_HOURS = RT.HOURS_PER_DAY,
STG.CURRENCY_CD = RT.CURRENCY_CD
WHERE STG.PROCESS_INSTANCE = 22195604
AND RT.EFFDT =
(SELECT MAX(RT1.EFFDT)
FROM PS_CTS_IQN_BU_RATE RT1
WHERE RT.BUSINESS_UNIT = RT1.BUSINESS_UNIT
AND RT1.EFFDT <= sysdate
)
AND STG.STANDARD_RATE = 0
AND STG.STANDARD_HOURS = 0
AND STG.BUSINESS_UNIT IN
( SELECT DISTINCT BUSINESS_UNIT FROM PS_CTS_IQN_BU_RATE
);
Best Answer
-
MERGE INTO PS_CT_IQN_ACC_STG STG USING PS_CTS_IQN_BU_RATE RT ON (STG.BUSINESS_UNIT = RT.BUSINESS_UNIT)
WHEN MATCHED THEN
UPDATE
SET STG.STANDARD_RATE = RT.STANDARD_RATE,
STG.STANDARD_HOURS = RT.HOURS_PER_DAY,
STG.CURRENCY_CD = RT.CURRENCY_CD
WHERE STG.PROCESS_INSTANCE = 22195604
AND RT.EFFDT =
(SELECT MAX(RT1.EFFDT)
FROM PS_CTS_IQN_BU_RATE RT1
WHERE RT.BUSINESS_UNIT = RT1.BUSINESS_UNIT
AND RT1.EFFDT <= sysdate
)
AND STG.STANDARD_RATE = 0
AND STG.STANDARD_HOURS = 0
AND STG.BUSINESS_UNIT IN
( SELECT DISTINCT BUSINESS_UNIT FROM PS_CTS_IQN_BU_RATE
);
Answers
-
MERGE INTO PS_CT_IQN_ACC_STG STG USING PS_CTS_IQN_BU_RATE RT ON (STG.BUSINESS_UNIT = RT.BUSINESS_UNIT)
WHEN MATCHED THEN
UPDATE
SET STG.STANDARD_RATE = RT.STANDARD_RATE,
STG.STANDARD_HOURS = RT.HOURS_PER_DAY,
STG.CURRENCY_CD = RT.CURRENCY_CD
WHERE STG.PROCESS_INSTANCE = 22195604
AND RT.EFFDT =
(SELECT MAX(RT1.EFFDT)
FROM PS_CTS_IQN_BU_RATE RT1
WHERE RT.BUSINESS_UNIT = RT1.BUSINESS_UNIT
AND RT1.EFFDT <= sysdate
)
AND STG.STANDARD_RATE = 0
AND STG.STANDARD_HOURS = 0
AND STG.BUSINESS_UNIT IN
( SELECT DISTINCT BUSINESS_UNIT FROM PS_CTS_IQN_BU_RATE
);
-
Get rid of the space on line 11 and retry.
Wrote file afiedt.buf
1 MERGE INTO PS_CT_IQN_ACC_STG STG USING PS_CTS_IQN_BU_RATE RT ON (STG.BUSINESS_UNIT = RT.BUSINESS_UNIT) 2 WHEN MATCHED THEN 3 UPDATE 4 SET STG.STANDARD_RATE = RT.STANDARD_RATE, 5 STG.STANDARD_HOURS = RT.HOURS_PER_DAY, 6 STG.CURRENCY_CD = RT.CURRENCY_CD 7 WHERE STG.PROCESS_INSTANCE = 22195604 8 AND RT.EFFDT = 9 (SELECT MAX(EFFDT)10 FROM PS_CTS_IQN_BU_RATE RT111 WHERE RT.BUSIN ESS_UNIT = RT1.BUSINESS_UNIT12 AND RT1.EFFDT <= sysdate13 )14 AND STG.STANDARD_RATE = 015 AND STG.STANDARD_HOURS = 016 AND STG.BUSINESS_UNIT IN17 ( SELECT DISTINCT BUSINESS_UNIT FROM PS_CTS_IQN_BU_RATE18* )19 / WHERE RT.BUSIN ESS_UNIT = RT1.BUSINESS_UNIT *ERROR at line 11:ORA-00920: invalid relational operatorSQL>