Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

ओरा-01427 सिंगल-पंक्ति सबक्वायरी को कैसे ठीक करें चयन में एक से अधिक पंक्ति लौटाता है?

निम्नलिखित क्वेरी का प्रयोग करें:

SELECT E.I_EmpID AS EMPID,
       E.I_EMPCODE AS EMPCODE,
       E.I_EmpName AS EMPNAME,
       REPLACE(TO_CHAR(A.I_REQDATE, 'DD-Mon-YYYY'), ' ', '') AS FROMDATE,
       REPLACE(TO_CHAR(A.I_ENDDATE, 'DD-Mon-YYYY'), ' ', '') AS TODATE,
       TO_CHAR(NOD) AS NOD,
       DECODE(A.I_DURATION,
              'FD',
              'FullDay',
              'FN',
              'ForeNoon',
              'AN',
              'AfterNoon') AS DURATION,
       L.I_LeaveType AS LEAVETYPE,
       REPLACE(TO_CHAR((SELECT max(C.I_WORKDATE)
                         FROM T_COMPENSATION C
                        WHERE C.I_COMPENSATEDDATE = A.I_REQDATE
                          AND C.I_EMPID = A.I_EMPID),
                       'DD-Mon-YYYY'),
               ' ',
               '') AS WORKDATE,
       A.I_REASON AS REASON,
       AP.I_REJECTREASON AS REJECTREASON
  FROM T_LEAVEAPPLY A
 INNER JOIN T_EMPLOYEE_MS E
    ON A.I_EMPID = E.I_EmpID
   AND UPPER(E.I_IsActive) = 'YES'
   AND A.I_STATUS = '1'
 INNER JOIN T_LeaveType_MS L
    ON A.I_LEAVETYPEID = L.I_LEAVETYPEID
  LEFT OUTER JOIN T_APPROVAL AP
    ON A.I_REQDATE = AP.I_REQDATE
   AND A.I_EMPID = AP.I_EMPID
   AND AP.I_APPROVALSTATUS = '1'
 WHERE E.I_EMPID <> '22'
 ORDER BY A.I_REQDATE DESC

चाल एक समग्र कार्य जोड़कर आंतरिक क्वेरी को केवल एक रिकॉर्ड वापस करने के लिए मजबूर करना है (मैंने यहां अधिकतम() का उपयोग किया है)। जहां तक ​​क्वेरी का संबंध है, यह पूरी तरह से काम करेगा, लेकिन, ईमानदारी से, ओपी को जांच करनी चाहिए कि आंतरिक क्वेरी डेटा की जांच करके कई रिकॉर्ड क्यों लौटा रही है। क्या ये एकाधिक रिकॉर्ड वास्तव में व्यवसाय के लिहाज से प्रासंगिक हैं?



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. क्या विदेशी कुंजी बाधाएं Oracle में क्वेरी परिवर्तनों को प्रभावित करती हैं?

  2. विंडोज़ में फ़ाइल में ऑरैकल एसक्यूएल परिणाम कैसे आउटपुट करें?

  3. ओरेकल लाइव एसक्यूएल

  4. एक ही दृश्य में दूसरे कॉलम की गणना करने के लिए परिकलित कॉलम का उपयोग कैसे करें

  5. Oracle डेटाबेस अद्यतन प्रश्नों में अनंत रूप से लटक रहा है