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

क्या पैरामीटर का उपयोग करके कई पंक्तियों का चयन करने का कोई तरीका है?

आप केवल क्वेरी का उपयोग करके Oracle में सेट किए गए परिणाम को वापस नहीं कर सकते। इसके लिए आपको रेफ कर्सर का उपयोग करना होगा। आप नीचे दिए गए कोड को आजमा सकते हैं -

CREATE OR REPLACE PROCEDURE p_find_all_routes (
   p_start   IN VARCHAR2 DEFAULT '%',
   p_end     IN VARCHAR2 DEFAULT '%',
   p_via     IN VARCHAR2 DEFAULT '%',
   multiroutes OUT SYS_REFCURSOR)
AS
BEGIN
   -- =======================================================================
   -- Author:       Coilin P. Boylan Jeritslev (CTBJ)
   -- Description:   Find all possible routes between two different points
   -- "p_start" and "p_end" via the choosen point "p_via" in a graph-tabel.
   -- =======================================================================
OPEN multiroutes FOR
   WITH multiroutes (p_from, p_to, full_route, total_distance)
        AS (SELECT p_from,
                   p_to,
                   p_from || '->' || p_to full_route,
                   distance total_distance
              FROM graph
             WHERE p_from LIKE p_start
            UNION ALL
            SELECT M.p_from,
                   n.p_to,
                   M.full_route || '->' || n.p_to full_route,
                   M.total_distance + n.distance total_distance
              FROM multiroutes M JOIN graph n ON M.p_to = n.p_from
             WHERE n.p_to <> ALL (M.full_route))
     SELECT *
       FROM multiroutes
      WHERE     p_to LIKE p_end
            AND (   full_route LIKE ('%->' || p_via || '%')
                 OR full_route LIKE ('%' || p_via || '->%'))
   ORDER BY p_from, p_to, total_distance ASC;
END;
/

फिर आप इस प्रक्रिया को बाद में Ref कर्सर चर घोषित करके कॉल कर सकते हैं।

DECLARE
    Result SYS_REFCURSOR;
BEGIN
    p_find_all_routes('A','E','%', Result);
END; 




  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 SQL पुनरावर्तन

  2. कैसे ओरेकल एसक्यूएल क्वेरी में कोष्ठक के बीच एक स्ट्रिंग निकालने के लिए?

  3. ORA-00907 दायां कोष्ठक समस्या गुम है - इनसाइड इंसर्ट क्वेरी द्वारा ऑर्डर के साथ चयन करें

  4. कैसे एसक्यूएल में सप्ताह संख्या निकालने के लिए

  5. कैसे एक संग्रहीत समारोह या प्रक्रिया का उपयोग किए बिना, एक रिटर्न वैल्यू पैरामीटर के रूप में सी # ODP.NET से एक Oracle रेफ कर्सर का उपयोग करने के लिए?