我需要在php脚本中编写2个mysql查询,在这两种情况下我都希望从同一服务器上的两个不同数据库中获取数据。但是这些数据库名称存储在两个不同的变量中。
$link1 = mysql_connect($hostname_database,$username_database,$password_database);
$database1 = "android1";
$database2= "android2";
$result1 = mysql_query("Select * from database1.tablename");
$result2 = mysql_query("Select * from database2.tablename");
实现这一目标的正确方法是什么?
答案 0 :(得分:2)
这是您连接两个数据库的方式。您需要在第二个连接中发送true作为第四个参数,否则将使用第一个连接。
$db1 = mysql_connect($hostname, $username, $password);
$db2 = mysql_connect($hostname, $username, $password, true);
mysql_select_db('database1', $db1);
mysql_select_db('database2', $db2);
然后查询第一个数据库:
mysql_query('select * from tablename', $db1);
查询第二个数据库:
mysql_query('select * from tablename', $db2);
编辑1:我从SO答案中使用了这个,但似乎无法找到答案。
编辑2:找到它:How do you connect to multiple MySQL databases on a single webpage?
编辑3:首选方式:
如果您使用PHP5(并且您应该,因为PHP4已被弃用),您应该使用PDO,因为这正逐渐成为新标准。 PDO的一个(非常)重要的好处是它支持绑定参数,这使得代码更加安全。
您将通过PDO连接,如下所示:
try {
$db = new PDO('mysql:dbname=databasename;host=127.0.0.1', 'username', 'password');
} catch (PDOException $ex) {
echo 'Connection failed: ' . $ex->getMessage();
}
(当然替换上面的数据库名,用户名和密码)
然后您可以像这样查询数据库:
$result = $db->query("select * from tablename");
foreach ($result as $row) {
echo $row['foo'] . "\n";
}
或者,如果您有变量:
$stmt = $db->prepare("select * from tablename where id = :id");
$stmt->execute(array(':id' => 42));
$row = $stmt->fetch();
如果您需要一次打开多个连接,您只需创建多个PDO实例:
try {
$db1 = new PDO('mysql:dbname=databas1;host=127.0.0.1', 'username', 'password');
$db2 = new PDO('mysql:dbname=databas2;host=127.0.0.1', 'username', 'password');
} catch (PDOException $ex) {
echo 'Connection failed: ' . $ex->getMessage();
}
答案 1 :(得分:0)
而是使用PDO对象来做同样的事情。
最新的事情+ mysqli_query将在未来版本的php中弃用
<?php
/*Function Definition*/
function getDbConnection($dbName,$qry)
{
$db = new PDO('mysql:host=localhost;dbname='.$dbName,'username','password');
$stmt = $db->query($qry);
return $stmt->fetchAll(PDO::FETCH_ASSOC);
}
/*Call the Function*/
$resultSet = getDbConnection(database1,$YourQuery);
?>