MySQLi Metadata को प्राप्त करना और उसका उपयोग करना

वहाँ तीन informations हैं, जो आप MySQLi से लेना चाहेंगे।

  • Information about the result of queries - इसमें किसी भी SELECT, UPDATE या DELETE स्टेटमेंट से प्रभावित रिकॉर्ड की संख्या शामिल है।

  • Information about tables and databases - इसमें टेबल और डेटाबेस की संरचना से संबंधित जानकारी शामिल है।

  • Information about the MySQLi server - इसमें डेटाबेस सर्वर की वर्तमान स्थिति, संस्करण संख्या आदि शामिल हैं।

यह सभी जानकारी mysqli प्रॉम्प्ट पर प्राप्त करना बहुत आसान है, लेकिन PERL या PHP APIs का उपयोग करते समय, हमें इन सभी सूचनाओं को प्राप्त करने के लिए स्पष्ट रूप से विभिन्न API को कॉल करने की आवश्यकता है। निम्नलिखित अनुभाग आपको दिखाएगा कि यह जानकारी कैसे प्राप्त करें।

एक क्वेरी से प्रभावित पंक्तियों की संख्या प्राप्त करना

पर्ल उदाहरण

DBI स्क्रिप्ट्स में, प्रभावित पंक्तियों की गिनती को () या निष्पादित () के आधार पर वापस किया जाता है, इस आधार पर कि आप क्वेरी को कैसे निष्पादित करते हैं -

# Method 1
# execute $query using do( )
my $count = $dbh->do ($query);
# report 0 rows if an error occurred
printf "%d rows were affected\n", (defined ($count) ? $count : 0);

# Method 2
# execute query using prepare( ) plus execute( )
my $sth = $dbh->prepare ($query);
my $count = $sth->execute ( );
printf "%d rows were affected\n", (defined ($count) ? $count : 0);

PHP उदाहरण

PHP में, mysqli_affected_rows () फ़ंक्शन का पता लगाने के लिए कि कितनी पंक्तियों को एक क्वेरी में बदला गया है -

$result_id = mysqli_query ($query, $conn_id);
# report 0 rows if the query failed
$count = ($result_id ? mysqli_affected_rows ($conn_id) : 0);
print ("$count rows were affected\n");

सूची सारणी और डेटाबेस

डेटाबेस सर्वर के साथ उपलब्ध सभी डेटाबेस और तालिकाओं को सूचीबद्ध करना बहुत आसान है। यदि आपके पास पर्याप्त विशेषाधिकार नहीं हैं तो आपका परिणाम शून्य हो सकता है।

नीचे दी गई विधि के अलावा, आप PHP या PERL में या तो तालिकाओं या डेटाबेस की सूची प्राप्त करने के लिए SHOW TABLES या SHOW DATABASES प्रश्नों का उपयोग कर सकते हैं।

पर्ल उदाहरण

# Get all the tables available in current database.
my @tables = $dbh->tables ( );
foreach $table (@tables ){
   print "Table Name $table\n";
}

PHP उदाहरण

<?php
   $servername = "localhost:3306";
   $username = "root";
   $password = "";
   $dbname = "TUTORIALS";
   $conn = new mysqli($servername, $username, $password, $dbname);
   
   if ($conn->connect_error) {
      die("Connection failed: " . $conn->connect_error);
   } 
   echo"Database connected";
   $sql="SHOW DATABASES";
   
   if (!($result = mysqli_query($conn,$sql))) {
      printf("Error: %s\n", mysqli_error($conn));
   }
   while( $row = mysqli_fetch_row( $result ) ){
      if (($row[0]!="information_schema") && ($row[0]!="mysql")) {
         echo $row[0]."\r\n";
      }
   }
   $conn->close();
?>

सर्वर मेटाडेटा प्राप्त करना

MySQL में निम्नलिखित कमांड हैं जिन्हें mysql प्रॉम्प्ट पर निष्पादित किया जा सकता है या डेटाबेस जैसी विभिन्न महत्वपूर्ण सूचना प्राप्त करने के लिए PHP जैसी किसी भी स्क्रिप्ट का उपयोग किया जा सकता है।

अनु क्रमांक। कमांड और विवरण
1

SELECT VERSION( )

सर्वर संस्करण स्ट्रिंग

2

SELECT DATABASE( )

वर्तमान डेटाबेस नाम (खाली यदि कोई नहीं)

3

SELECT USER( )

वर्तमान उपयोगकर्ता नाम

4

SHOW STATUS

सर्वर स्थिति संकेतक

5

SHOW VARIABLES

सर्वर कॉन्फ़िगरेशन चर