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

SQL में दो तालिकाओं से पंक्तियों के सभी संभावित संयोजन कैसे प्राप्त करें

समस्या:

आप SQL में दो तालिकाओं से पंक्तियों के सभी संयोजन प्राप्त करना चाहते हैं।

उदाहरण:

यहां दो टेबल हैं:एक में अक्षर होते हैं (letters ), और दूसरे में संख्याएँ होती हैं (numbers ):

पत्र
X
Y
संख्या
0
1
2

समाधान 1:

letters numbers तालिका, हम CROSS JOIN का उपयोग करेंगे :

SELECT *
FROM letters
CROSS JOIN numbers;

क्वेरी का परिणाम इस तरह दिखता है:

पत्र संख्या
X 0
Y 0
X 1
Y 1
X 2
Y 2

समाधान 2:

क्रॉस जॉइन करने का दूसरा तरीका इस प्रकार है:

SELECT *
FROM letters, numbers;

यह ठीक वही परिणाम प्राप्त करेगा जो पिछली क्वेरी द्वारा उत्पन्न किया गया था।

चर्चा:

एक सामान्य नियम के रूप में, एक CROSS JOIN एक परिणाम सेट उत्पन्न करता है जिसमें एक तालिका से प्रत्येक पंक्ति दूसरी तालिका की प्रत्येक पंक्ति से जुड़ जाती है। दूसरे शब्दों में, यदि पहली तालिका n . को संग्रहीत करती है पंक्तियाँ और दूसरी तालिका m संग्रहीत करती है पंक्तियाँ, फिर एक CROSS JOIN परिणामस्वरूप एक कार्टेशियन उत्पाद . होगा का n × m पंक्तियाँ। यही कारण है कि ऊपर के उदाहरण में क्वेरी द्वारा छह पंक्तियाँ दी गई हैं।

क्योंकि एक CROSS JOIN शामिल होने वाली तालिकाओं के बीच पंक्तियों के सभी संभावित संयोजनों का उत्पादन करता है, संबंध निर्दिष्ट करने की कोई आवश्यकता नहीं है। तो, अन्य JOINs के विपरीत , कोई ON नहीं है CROSS JOIN में क्लॉज ।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. एसक्यूएल चयन MAX

  2. अनुयायी समूह - SQL और NoSQL परिनियोजन को सिंक करने के लिए 3 प्रमुख उपयोग के मामले

  3. हैलोवीन समस्या - भाग 1

  4. डेटा माइग्रेशन

  5. क्लस्टर सत्यापन उपयोगिता "/u01" फाइल सिस्टम पर बड़ी संख्या में एक्सएमएल फाइलें उत्पन्न करती है।