MySQL - Datenbankinfo
Abrufen und Verwenden von MySQL-Metadaten
Es gibt drei Arten von Informationen, die Sie von MySQL erhalten möchten.
Information about the result of queries - Dies schließt die Anzahl der Datensätze ein, die von einer SELECT-, UPDATE- oder DELETE-Anweisung betroffen sind.
Information about the tables and databases - Dies beinhaltet Informationen zur Struktur der Tabellen und Datenbanken.
Information about the MySQL server - Dies beinhaltet den Status des Datenbankservers, die Versionsnummer usw.
Es ist sehr einfach, alle diese Informationen an der MySQL-Eingabeaufforderung abzurufen. Bei Verwendung von PERL- oder PHP-APIs müssen jedoch verschiedene APIs explizit aufgerufen werden, um alle diese Informationen abzurufen.
Abrufen der Anzahl der von einer Abfrage betroffenen Zeilen
Lassen Sie uns nun sehen, wie Sie diese Informationen erhalten.
PERL Beispiel
In DBI-Skripten wird die Anzahl der betroffenen Zeilen von der zurückgegeben do( ) oder von der execute( ) Befehl, abhängig davon, wie Sie die Abfrage ausführen.
# 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 Beispiel
Rufen Sie in PHP die auf mysql_affected_rows( ) Funktion, um herauszufinden, wie viele Zeilen eine Abfrage geändert hat.
$result_id = mysql_query ($query, $conn_id);
# report 0 rows if the query failed
$count = ($result_id ? mysql_affected_rows ($conn_id) : 0);
print ("$count rows were affected\n");
Auflisten von Tabellen und Datenbanken
Es ist sehr einfach, alle mit einem Datenbankserver verfügbaren Datenbanken und Tabellen aufzulisten. Ihr Ergebnis kann seinnull wenn Sie nicht über die erforderlichen Berechtigungen verfügen.
Abgesehen von der Methode, die im folgenden Codeblock gezeigt wird, können Sie verwenden SHOW TABLES oder SHOW DATABASES Abfragen, um die Liste der Tabellen oder Datenbanken entweder in PHP oder in PERL abzurufen.
PERL Beispiel
# Get all the tables available in current database.
my @tables = $dbh->tables ( );
foreach $table (@tables ){
print "Table Name $table\n";
}
PHP Beispiel
<?php
$con = mysql_connect("localhost", "userid", "password");
if (!$con) {
die('Could not connect: ' . mysql_error());
}
$db_list = mysql_list_dbs($con);
while ($db = mysql_fetch_object($db_list)) {
echo $db->Database . "<br />";
}
mysql_close($con);
?>
Server-Metadaten abrufen
Es gibt einige wichtige Befehle in MySQL, die entweder an der MySQL-Eingabeaufforderung oder mithilfe eines Skripts wie PHP ausgeführt werden können, um verschiedene wichtige Informationen über den Datenbankserver abzurufen.
Sr.Nr. | Befehl & Beschreibung |
---|---|
1 | SELECT VERSION( ) Serverversionszeichenfolge |
2 | SELECT DATABASE( ) Aktueller Datenbankname (leer, wenn keiner) |
3 | SELECT USER( ) Aktueller Benutzername |
4 | SHOW STATUS Serverstatusanzeigen |
5 | SHOW VARIABLES Serverkonfigurationsvariablen |