⊗ppPmDOGD 382 of 447 menu

PHP में संबंधित टेबल्स से डेटा प्राप्त करना

आइए एक क्वेरी बनाते हैं जो सभी उपयोगकर्ताओं को उनके शहरों के साथ प्राप्त करेगी। इसके लिए हमें LEFT JOIN कमांड की आवश्यकता होगी:

इसका सिंटैक्स निम्नलिखित प्रकार से दिखता है:

SELECT fields FROM table_name LEFT JOIN related_table_name ON link_condition WHERE selection_condition

आइए इस कमांड के सिंटैक्स के अलग-अलग भागों को समझते हैं।

फ़ील्ड्स

चूंकि चयन कई टेबल्स से हो रहा है, इसलिए * के माध्यम से सभी फ़ील्ड्स का चयन काम नहीं करेगा। निम्नलिखित क्वेरी केवल मुख्य टेबल से फ़ील्ड्स चुनेगी, लेकिन संबंधित टेबल से नहीं:

SELECT *

ताकि डेटा सभी टेबल्स से चुना जाए, * से पहले टेबल का नाम निर्दिष्ट करना होगा:

SELECT users.*, cities.*

या फिर हम आवश्यक फ़ील्ड्स को उनसे पहले टेबल का नाम निर्दिष्ट करके सूचीबद्ध कर सकते हैं:

SELECT users.name, cities.name

इन दोनों तरीकों में एक समस्या है। मुद्दा यह है कि यदि टेबल्स में फ़ील्ड्स के नाम समान हैं, तो PHP ऐरे में नामों का टकराव हो जाएगा और केवल एक फ़ील्ड जीतेगा, और दूसरा नहीं होगा।

समस्या के समाधान के लिए टकराव वाले नामों को as कमांड के माध्यम से बदलना होगा:

SELECT users.name, cities.name as city_name

संबंध

ON कमांड के बाद हमें दो टेबल्स से उन फ़ील्ड्स को निर्दिष्ट करना होगा, जिनके माध्यम से संबंध स्थापित होता है। हमारे मामले में यह id फ़ील्ड शहरों वाली टेबल से और city_id फ़ील्ड उपयोगकर्ताओं वाली टेबल से होगा:

ON cities.id=users.city_id

क्वेरी

अंतत: वह क्वेरी, जो उपयोगकर्ताओं को उनके शहरों के साथ प्राप्त करेगी, निम्नलिखित प्रकार से दिखेगी:

SELECT users.name, cities.name as city_name FROM users LEFT JOIN cities ON cities.id=users.city_id

व्यावहारिक कार्य

मान लीजिए आपके पास उत्पादों की एक टेबल और उनकी श्रेणियों की एक टेबल है। एक क्वेरी लिखें जो उत्पादों के नाम उनकी श्रेणियों के साथ प्राप्त करे।

हिन्दी
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
हम साइट के कार्य, विश्लेषण और व्यक्तिगतकरण के लिए कुकीज़ का उपयोग करते हैं। डेटा प्रसंस्करण गोपनीयता नीति के अनुसार किया जाता है।
सभी स्वीकार करें कॉन्फ़िगर करें अस्वीकार करें