两个不同数据库之间的连接

时间:2010-11-26 06:58:19

标签: php database-connection

我在不同的服务器上有两种数据库。以下脚本是为了建立数据库连接:

//DB 1
define("DBNAME","xx.xxx.xx.xxx:D:\DATABASE\OCS DATA.FDB"); 
define("DBUSER","USER"); 
define("DBPASS","USER"); 
$dbh = ibase_connect(DBNAME,DBUSER,DBPASS) or die(_ERROR15.": ".ibase_errmsg());

//DB 2
$dbc=mysql_connect(_SRV, _ACCID, _PWD) or die(_ERROR15.": ".mysql_error());
mysql_select_db("qdbase") or die(_ERROR17.": ".mysql_error());

除此之外,我有一些查询将数据插入另一个数据库:

//if structure of the both tables are same then...
$sql = "insert into database1.member select * from database2.member";

//if structure of both tables are not same then
$sql = "Insert into database1.member select columnname1,columnname2 ".
       "from database2.member";

此查询是否可用于上述条件,它有两种不同类型的DB?如果是这样,哪一部分必须改变?


while ($ibase_row = ibase_fetch_assoc($rResult)){
  $ins = array();
  foreach ($ibase_row as $col => $val){
    $ins[$col] = mysql_real_escape_string($val);
  }

  $mysql_insert = "INSERT INTO qdbase.table SET ".implode(',', $ins);
  $res = mysql_query($mysql_insert, $dbc) or die();
}

1 个答案:

答案 0 :(得分:0)

您的数据库系统有可能支持“dblink”功能。

如果可以,你可以将mysql链接到Firebird,反之亦然,然后从其中一个运行脚本。