MySQl जॉइन का उपयोग करना
पिछले अध्यायों में, हमें एक बार में एक तालिका से डेटा मिल रहा था। यह साधारण ले के लिए काफी अच्छा है, लेकिन अधिकांश वास्तविक दुनिया में MySQL usages, आप अक्सर एक ही क्वेरी में कई तालिकाओं से डेटा प्राप्त करने की आवश्यकता होगी।
आप अपनी एकल SQL क्वेरी में कई तालिकाओं का उपयोग कर सकते हैं। MySQL में शामिल होने का कार्य एक ही तालिका में दो या अधिक तालिकाओं को नष्ट करने को संदर्भित करता है।
MySQL टेबल में शामिल होने के लिए आप SELECT, UPDATE और DELETE स्टेटमेंट में JOINS का उपयोग कर सकते हैं। हम LEFT JOIN का एक उदाहरण देखेंगे जो कि साधारण MySQL JOIN से अलग है।
कमांड प्रॉम्प्ट में जॉइन का उपयोग करना
मान लें कि हमारे पास दो टेबल हैं tcount_tbl तथा tutorials_tbl, TUTORIALS में। अब नीचे दिए गए उदाहरणों पर एक नज़र डालें -
उदाहरण
निम्नलिखित उदाहरण -
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT * FROM tcount_tbl;
+-----------------+----------------+
| tutorial_author | tutorial_count |
+-----------------+----------------+
| mahran | 20 |
| mahnaz | NULL |
| Jen | NULL |
| Gill | 20 |
| John Poul | 1 |
| Sanjay | 1 |
+-----------------+----------------+
6 rows in set (0.01 sec)
mysql> SELECT * from tutorials_tbl;
+-------------+----------------+-----------------+-----------------+
| tutorial_id | tutorial_title | tutorial_author | submission_date |
+-------------+----------------+-----------------+-----------------+
| 1 | Learn PHP | John Poul | 2007-05-24 |
| 2 | Learn MySQL | Abdul S | 2007-05-24 |
| 3 | JAVA Tutorial | Sanjay | 2007-05-06 |
+-------------+----------------+-----------------+-----------------+
3 rows in set (0.00 sec)
mysql>
अब हम इन दो तालिकाओं में शामिल होने के लिए एक SQL क्वेरी लिख सकते हैं। यह क्वेरी तालिका से सभी लेखकों का चयन करेगीtutorials_tbl और इसी ट्यूटोरियल की संख्या को उठाएगा tcount_tbl।
mysql> SELECT a.tutorial_id, a.tutorial_author, b.tutorial_count
-> FROM tutorials_tbl a, tcount_tbl b
-> WHERE a.tutorial_author = b.tutorial_author;
+-------------+-----------------+----------------+
| tutorial_id | tutorial_author | tutorial_count |
+-------------+-----------------+----------------+
| 1 | John Poul | 1 |
| 3 | Sanjay | 1 |
+-------------+-----------------+----------------+
2 rows in set (0.01 sec)
mysql>
PHP स्क्रिप्ट में Joins का उपयोग करना
आप PHP स्क्रिप्ट में उपर्युक्त SQL क्वेरी में से किसी का उपयोग कर सकते हैं। आपको केवल SQL फ़ंक्शन को PHP फ़ंक्शन में पास करना होगाmysql_query() और फिर आप सामान्य तरीके से परिणाम प्राप्त करेंगे।
उदाहरण
निम्न उदाहरण -
<?php
$dbhost = 'localhost:3036';
$dbuser = 'root';
$dbpass = 'rootpassword';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
if(! $conn ) {
die('Could not connect: ' . mysql_error());
}
$sql = 'SELECT a.tutorial_id, a.tutorial_author, b.tutorial_count
FROM tutorials_tbl a, tcount_tbl b
WHERE a.tutorial_author = b.tutorial_author';
mysql_select_db('TUTORIALS');
$retval = mysql_query( $sql, $conn );
if(! $retval ) {
die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) {
echo "Author:{$row['tutorial_author']} <br> ".
"Count: {$row['tutorial_count']} <br> ".
"Tutorial ID: {$row['tutorial_id']} <br> ".
"--------------------------------<br>";
}
echo "Fetched data successfully\n";
mysql_close($conn);
?>
MySQL बाएँ शामिल हैं
एक MySQL लेफ्ट जॉइन एक साधारण जॉइन से अलग है। MySQL LEFT JOIN बाईं ओर स्थित तालिका के लिए कुछ अतिरिक्त विचार देता है।
अगर मैं ए LEFT JOIN, मुझे उसी तरह से मेल खाने वाले सभी रिकॉर्ड मिलते हैं और प्रवेश में मुझे शामिल होने की बाईं तालिका में प्रत्येक बेजोड़ रिकॉर्ड के लिए एक अतिरिक्त रिकॉर्ड मिलता है: इस प्रकार यह सुनिश्चित करना (मेरे उदाहरण में) कि हर AUTHOR को एक उल्लेख मिलता है।
उदाहरण
LEFT JOIN को समझने के लिए निम्न उदाहरण को आजमाएँ।
root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT a.tutorial_id, a.tutorial_author, b.tutorial_count
-> FROM tutorials_tbl a LEFT JOIN tcount_tbl b
-> ON a.tutorial_author = b.tutorial_author;
+-------------+-----------------+----------------+
| tutorial_id | tutorial_author | tutorial_count |
+-------------+-----------------+----------------+
| 1 | John Poul | 1 |
| 2 | Abdul S | NULL |
| 3 | Sanjay | 1 |
+-------------+-----------------+----------------+
3 rows in set (0.02 sec)
आपको JOINS से परिचित होने के लिए अधिक अभ्यास करने की आवश्यकता होगी। यह MySQL / SQL में थोड़ी जटिल अवधारणा है और वास्तविक उदाहरण करते समय अधिक स्पष्ट हो जाएगी।