MariaDB - सम्मिलित हों
पिछली चर्चाओं और उदाहरणों में, हमने एक ही तालिका से पुनर्प्राप्ति की जांच की, या कई स्रोतों से कई मान प्राप्त किए। अधिकांश वास्तविक-विश्व डेटा ऑपरेशन अधिक जटिल होते हैं, जिनमें कई तालिकाओं से एकत्रीकरण, तुलना और पुनर्प्राप्ति की आवश्यकता होती है।
JOINsएक ही वस्तु में दो या दो से अधिक तालिकाओं के विलय की अनुमति दें। वे SELECT, UPDATE और DELETE कथनों के माध्यम से कार्यरत हैं।
नीचे दिखाए गए अनुसार एक JOIN को नियोजित करने वाले कथन के सामान्य सिंटैक्स की समीक्षा करें -
SELECT column
FROM table_name1
INNER JOIN table_name2
ON table_name1.column = table_name2.column;
JOINS के लिए पुराने वाक्यविन्यास का उपयोग करें निहितार्थ और कोई कीवर्ड नहीं। ज्वाइन करने के लिए WHERE क्लॉज का उपयोग करना संभव है, लेकिन कीवर्ड पठनीयता, रखरखाव और सर्वोत्तम प्रथाओं के लिए सबसे अच्छा काम करते हैं।
जॉइन कई रूपों में आते हैं जैसे कि लेफ्ट जॉइन, राइट जॉइन या इनर जॉइन। विभिन्न प्रकार के प्रकार साझा मूल्यों या विशेषताओं के आधार पर विभिन्न प्रकार के एकत्रीकरण प्रदान करते हैं।
कमांड प्रॉम्प्ट पर या PHP स्क्रिप्ट के साथ एक जॉइन को रोजगार दें।
कमांड प्रॉम्प्ट
कमांड प्रॉम्प्ट पर, बस एक मानक स्टेटमेंट का उपयोग करें -
root@host# mysql -u root -p password;
Enter password:*******
mysql> use PRODUCTS;
Database changed
mysql> SELECT products.ID_number, products.Nomenclature, inventory.inventory_ct
FROM products
INNER JOIN inventory
ON products.ID_numbeer = inventory.ID_number;
+-------------+----------------+-----------------+
| ID_number | Nomenclature | Inventory Count |
+-------------+----------------+-----------------+
| 12345 | Orbitron 4000 | 150 |
+-------------+----------------+-----------------+
| 12346 | Orbitron 3000 | 200 |
+-------------+----------------+-----------------+
| 12347 | Orbitron 1000 | 0 |
+-------------+----------------+-----------------+
PHP स्क्रिप्ट JOIN का उपयोग करना
उपयोग 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.product_id, a.product_manufacturer, b.product_count
FROM products_tbl a, pcount_tbl b
WHERE a.product_manufacturer = b.product_manufacturer';
mysql_select_db('PRODUCTS');
$retval = mysql_query( $sql, $conn );
if(! $retval ) {
die('Could not get data: ' . mysql_error());
}
while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) {
echo "Manufacturer:{$row['product_manufacturer']} <br> ".
"Count: {$row['product_count']} <br> ".
"Product ID: {$row['product_id']} <br> ".
"--------------------------------<br>";
}
echo "Fetched data successfully\n";
mysql_close($conn);
?>
सफल डेटा पुनर्प्राप्ति पर, आप निम्न आउटपुट देखेंगे -
ID Number: 12345
Nomenclature: Orbitron 4000
Inventory Count: 150
--------------------------------------
ID Number: 12346
Nomenclature: Orbitron 3000
Inventory Count: 200
--------------------------------------
ID Number: 12347
Nomenclature: Orbitron 1000
Inventory Count: 0
--------------------------------------
mysql> Fetched data successfully