PHP同時連接多個mysql數(shù)據(jù)庫示例代碼
來源:易賢網(wǎng) 閱讀:804 次 日期:2014-08-22 11:03:23
溫馨提示:易賢網(wǎng)小編為您整理了“PHP同時連接多個mysql數(shù)據(jù)庫示例代碼”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了PHP同時連接多個mysql數(shù)據(jù)庫的具體實現(xiàn),需要的朋友可以參考下

實例:

代碼如下:

<?php

$conn1 = mysql_connect("127.0.0.1", "root","root","db1");

mysql_select_db("db1", $conn1);

$conn2 = mysql_connect("127.0.0.1", "root","root","db2");

mysql_select_db("db2", $conn2);

$sql = "select * from ip";

$query = mysql_query($sql);

if($row = mysql_fetch_array($query))

echo $row[0]."n";

$sql = "select * from web ";

$query = mysql_query($sql);

if($row = mysql_fetch_array($query))

echo $row[0];

?>

這段代碼存在問題,在程序執(zhí)行時會報錯:PHP Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given in ....

原因分析:

程序開始建立兩個數(shù)據(jù)庫鏈接,函數(shù)mysql_query()原型:

resource mysql_query ( string $query [, resource $link_identifier ] )

向與指定的連接標識符關(guān)聯(lián)的服務器中的當前活動數(shù)據(jù)庫發(fā)送一條查詢。如果沒有指定 link_identifier,則使用上一個打開的連接。如果沒有打開的連接,本函數(shù)會嘗試無參數(shù)調(diào)用 mysql_connect() 函數(shù)來建立一個連接并使用之。查詢結(jié)果會被緩存。

在本例中由于沒有指定link_identifier,所以,在執(zhí)行第一條sql時,默認使用的是上一個打開的鏈接,即$conn2,而實際上第一條sql語句應該使用的是$conn1,所以導致報錯,所以為了能夠鏈接多個mysql數(shù)據(jù)庫,可以使用如下方法:

方法1:在mysql_query函數(shù)中指定所用連接,即:

代碼如下:

<?php

$conn1 = mysql_connect("127.0.0.1", "root","root","db1");

mysql_select_db("Muma", $conn1);

$conn2 = mysql_connect("127.0.0.1", "root","root","db2");

mysql_select_db("product", $conn2);

$sql = "select * from ip";

$query = mysql_query($sql,$conn1); //添加連接$conn1

if($row = mysql_fetch_array($query))

echo $row[0]."n";

$sql = "select * from web ";

$query = mysql_query($sql, $conn2);

if($row = mysql_fetch_array($query))

echo $row[0];

?>

方法2:在sql語句中關(guān)聯(lián)所用數(shù)據(jù)庫,此時可以省略mysql_query的第二個參數(shù),即:

代碼如下:

<?php

$conn1 = mysql_connect("127.0.0.1", "root","root","db1");

mysql_select_db("db1", $conn1);

$conn2 = mysql_connect("127.0.0.1", "root","root","db2");

mysql_select_db("db2", $conn2);

$sql = "select * from db1.ip"; //關(guān)聯(lián)數(shù)據(jù)庫

$query = mysql_query($sql);

if($row = mysql_fetch_array($query))

echo $row[0]."n";

$sql = "select * from db2.web ";

$query = mysql_query($sql);

if($row = mysql_fetch_array($query))

echo $row[0];

?>

更多信息請查看IT技術(shù)專欄

更多信息請查看網(wǎng)絡編程
易賢網(wǎng)手機網(wǎng)站地址:PHP同時連接多個mysql數(shù)據(jù)庫示例代碼

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)