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

SQL अद्यतन विभाजन वाक्य पर एक चयन रैंक में

आप उप-क्वेरी . में शामिल हो सकते हैं और एक अद्यतन करें . करें :

UPDATE table_name t2
SET t2.rank=
  SELECT t1.rank FROM(
  SELECT company,
    direction,
    type,
    YEAR,
    MONTH,
    value,
    rank() OVER (PARTITION BY direction, type, YEAR, MONTH ORDER BY value DESC) AS rank
  FROM table_name
  GROUP BY company,
    direction,
    TYPE,
    YEAR,
    MONTH,
    VALUE
  ORDER BY company,
    direction,
    TYPE,
    YEAR,
    MONTH,
    VALUE
  ) t1
WHERE t1.company = t2.company
AND t1.direction = t2.direction;

विधेय में आवश्यक शर्तें जोड़ें।

या,

आप MERGE . का उपयोग कर सकते हैं और उस क्वेरी को उपयोग . में रखें खंड:

MERGE INTO table_name t USING
(SELECT company,
  direction,
  TYPE,
  YEAR,
  MONTH,
  VALUE,
  rank() OVER (PARTITION BY direction, TYPE, YEAR, MONTH ORDER BY VALUE DESC) AS rank
FROM table1
GROUP BY company,
  direction,
  TYPE,
  YEAR,
  MONTH,
  VALUE
ORDER BY company,
  direction,
  TYPE,
  YEAR,
  MONTH,
  VALUE
) s 
ON(t.company = s.company AND t.direction = s.direction)
WHEN MATCHED THEN
  UPDATE SET t.rank = s.rank;

ON क्लॉज में आवश्यक शर्तें जोड़ें।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. यदि पासवर्ड में विशेष वर्ण हैं तो JDBC का उपयोग करके Oracle डेटाबेस से कनेक्ट करने में सक्षम नहीं है

  2. ऑरैकल डीबी में एकाधिक क्षेत्रों के साथ सशर्त अद्वितीय बाधा

  3. ओरेकल 12.1.0.2 . पर भारी अदला-बदली

  4. पीएल/एसक्यूएल फ़ंक्शन में पास एरे का उपयोग कैसे करें

  5. Oracle संग्रहित प्रक्रिया और कर्सर