調(diào)用MySQL中數(shù)據(jù)庫元數(shù)據(jù)的方法
MySQL的三個信息:
- 查詢的結(jié)果有關的信息: 這包括由任何SELECT,UPDATE或DELETE語句產(chǎn)生數(shù)量的記錄。
- 表和數(shù)據(jù)庫有關的信息: 這包括表和數(shù)據(jù)庫的結(jié)構(gòu)有關的信息。
- MySQL服務器的信息: 這包括當前狀態(tài)的數(shù)據(jù)庫服務器,版本號等。
在mysql提示符下很容易獲得所有這些信息。但是,當使用Perl或PHP的API,那么我們就需要顯式地調(diào)用各種API獲得所有這些信息。下面的部分將告訴你如何獲得這些信息。
獲取查詢所影響的行數(shù):
PERL 實例:
在DBI腳本中,受影響的行數(shù)由do()或execute()方法返回,這取決于如何執(zhí)行查詢:
# 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中,調(diào)用mysql_affected_rows()函數(shù)找出多少行查詢改變:
$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");
表和數(shù)據(jù)庫清單(列表):
很容易列出了所有與數(shù)據(jù)庫服務器的數(shù)據(jù)庫和表。如果沒有足夠的權限結(jié)果可能是空的。
除了方法,我剛才提到下面可以使用SHOW TABLES或SHOW DATABASES查詢的表或數(shù)據(jù)庫的列表,無論是在PHP或PERL。
PERL 實例:
# Get all the tables available in current database. my @tables = $dbh->tables ( ); foreach $table (@tables ){ print "Table Name $table\n"; }
PHP 實例:
<?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); ?>
獲取服務器的元數(shù)據(jù):
在MySQL可以執(zhí)行下面的命令是mysql提示符下使用,或使用任何腳本,如PHP,數(shù)據(jù)庫服務器獲取各種重要信息。
相關文章
MySQL中將一列以逗號分隔的值行轉(zhuǎn)列的實現(xiàn)
這篇文章主要介紹了MySQL中將一列以逗號分隔的值行轉(zhuǎn)列的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-10-10mysql 實現(xiàn)添加時間自動添加更新時間自動更新操作
這篇文章主要介紹了mysql 實現(xiàn)添加時間自動添加更新時間自動更新操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01