MySQL-databaseHoe de status- en versienummergegevenstabelstructuurinformatie controleren?

MySQL Metadata

Misschien wilt u de volgende drie soorten informatie over MySQL weten:

  • Informatie over queryresultaten: Het aantal records dat wordt beïnvloed door de SELECT-, UPDATE- of DELETE-instructie.
  • Informatie over databases en datatabellen: Bevat de structuurinformatie van de database en de gegevenstabel.
  • MySQL-serverinformatie: Bevat de huidige status van de databaseserver, versienummer, enz.

In de MySQL-opdrachtprompt kunnen we eenvoudig de bovenstaande serverinformatie verkrijgen.Maar als u een scripttaal zoals Perl of PHP gebruikt, moet u een specifieke interfacefunctie aanroepen om deze te krijgen.Vervolgens zullen we in detail introduceren.


Het aantal records ophalen dat wordt beïnvloed door de query-instructie

PERL-instantie

In DBI-scripts wordt het aantal records dat door de instructie wordt beïnvloed, geretourneerd door de functies do( ) of 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);

PHP-instantie

In PHP kun je de functie mysqli_affected_rows( ) gebruiken om het aantal records te krijgen dat door een query wordt beïnvloed.

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

Lijst met databases en datatabellen

U kunt eenvoudig een lijst met databases en tabellen op de MySQL-server krijgen.Als u niet over voldoende machtigingen beschikt, zal het resultaat null retourneren.
U kunt ook de instructie SHOW TABLES of SHOW DATABASES gebruiken om een ​​lijst met databases en datatabellen te krijgen.

PERL-instantie

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

PHP-instantie

In het volgende voorbeeld worden alle databases op de MySQL-server uitgevoerd:

Bekijk alle databases

<?
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);
?>

Servermetadata ophalen

De volgende opdrachtinstructies kunnen worden gebruikt bij de MySQL-opdrachtprompt of in scripts, zoals PHP-scripts.

命令Omschrijving
KIES VERSIE( )Informatie over serverversie
SELECTEER DATABANK( )huidige databasenaam (of retour leeg)
SELECTEER GEBRUIKER( )huidige gebruikersnaam
TOON STATUSserver Status
TOON VARIABELENServerconfiguratievariabelen