MySQL databázeJak zkontrolovat informace o struktuře datové tabulky stavu a čísla verze?

MySQL metadata

Možná budete chtít znát následující tři druhy informací o MySQL:

  • Informace o výsledku dotazu: Počet záznamů ovlivněných příkazem SELECT, UPDATE nebo DELETE.
  • Informace o databázích a datových tabulkách: Obsahuje informace o struktuře databáze a datové tabulky.
  • Informace o serveru MySQL: Obsahuje aktuální stav databázového serveru, číslo verze atd.

V příkazovém řádku MySQL můžeme snadno získat výše uvedené informace o serveru.Pokud ale používáte skriptovací jazyk, jako je Perl nebo PHP, musíte k jeho získání zavolat konkrétní funkci rozhraní.Dále se podrobně představíme.


Získejte počet záznamů ovlivněných příkazem dotazu

instance PERL

Ve skriptech DBI je počet záznamů ovlivněných příkazem vrácen funkcemi do() nebo execute():

# 方法 1
# 使用do( ) 执行  $query 
my $count = $dbh->do ($query);
# 如果发生错误会输出 0
printf "%d 条数据被影响\n", (defined ($count) ? $count : 0);
# 方法 2
# 使用prepare( ) 及 execute( ) 执行  $query 
my $sth = $dbh->prepare ($query);
my $count = $sth->execute ( );
printf "%d 条数据被影响\n", (defined ($count) ? $count : 0);

instance PHP

V PHP můžete použít funkci mysqli_affected_rows() k získání počtu záznamů ovlivněných dotazem.

$result_id = mysqli_query ($conn_id, $query);
# 如果查询失败返回 
$count = ($result_id ? mysqli_affected_rows ($conn_id) : 0);
print ("$count 条数据被影响\n");

Seznam databází a datových tabulek

Můžete snadno získat seznam databází a tabulek na serveru MySQL.Pokud nemáte dostatečná oprávnění, výsledek vrátí hodnotu null.
K získání seznamu databází a datových tabulek můžete také použít příkaz SHOW TABLES nebo SHOW DATABASES.

instance PERL

# 获取当前数据库中所有可用的表。
my @tables = $dbh->tables ( );
foreach $table (@tables ){
   print "表名 $table\n";
}

instance PHP

Následující příklad zobrazuje všechny databáze na serveru MySQL:

Zobrazit všechny databáze

<?
php
$dbhost = 'localhost:3306'; // mysql服务器主机地址
$dbuser = 'root'; // mysql用户名
$dbpass = '123456'; // mysql用户名密码
$conn = mysqli_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
 die('连接失败: ' . mysqli_error($conn));
}
// 设置编码,防止中文乱码
$db_list = mysqli_query($conn, 'SHOW DATABASES');
while ($db = mysqli_fetch_object($db_list))
{
 echo $db->Database . "<br />";
}
mysqli_close($conn);
?>

Získejte metadata serveru

Následující příkazy lze použít na příkazovém řádku MySQL nebo ve skriptech, jako jsou skripty PHP.

命令popis
VYBRAT VERZI ( )Informace o verzi serveru
VYBRAT DATABÁZI( )název aktuální databáze (nebo návrat prázdný)
VYBRAT UŽIVATELE( )aktuální uživatelské jméno
ZOBRAZIT STAVstav serveru
ZOBRAZIT PROMĚNNÉProměnné konfigurace serveru