0

Firebird データベースからいくつかの列を選択し、MSSQL データベース テーブルに挿入したいと考えています。

Firebird からテーブルを読み取ると、ローカルホストで必要なものが正確に表され、データを MSSQL に挿入するときに、最後のレコードのみが挿入されます。何が原因なのかわかりませんが、このアイデアを試すのは初めてです。

誰かが何がうまくいかないのか教えてくれますか?

これは私のPHPコードです:

<?php
$host = 'localhost:c:\firebird.fdb'; 
$username=''; 
$password='';

$dbh = ibase_connect($host, $username, $password);
$stmt = "SELECT * FROM TWEEKDAY";
$sth = ibase_query($dbh, $stmt);
while ($row = ibase_fetch_object($sth)) {
$R1 = $row->CODE;
$R2 = $row->DAYNAME;
    echo $R1 ." ". $R2  . "\n";
    echo "</br>";
}
ibase_close($dbh);

/**********************************************/

$host = "servername\instancename";
$connectionInfo = array( "Database"=>"MSSQLdatabase", "UID"=>"", "PWD"=>"");
$conn = sqlsrv_connect( $host, $connectionInfo);
if( $conn === false ) {
    die( print_r( sqlsrv_errors(), true));
}
echo "</br>"; 

$tsql =  "INSERT INTO [AccessCard].[dbo].[WEEKDAY] (DAYID,DAYN) VALUES ('$R1','$R2')";

$stmt = sqlsrv_query( $conn, $tsql); 

if ( $stmt === false )    {    
     die( print_r( sqlsrv_errors(), true));    
} 
 while( $obj = sqlsrv_fetch_object( $stmt ,  SQLSRV_FETCH_ASSOC) ) {
      echo $obj->DAYID ."&nbsp ". $obj->DAYN . "<br />";
}
sqlsrv_free_stmt( $stmt);  
sqlsrv_close( $conn);
?>

コードを実行すると、ローカル ホストに次のように表示 ます 。

そして、私がこのコードを使用するとき:

<?php
$host = 'localhost:c:\FIREBIRD.fdb'; 
$username=''; 
$password='';

$dbh = ibase_connect($host, $username, $password);
$stmt = "SELECT * FROM TWEEKDAY";
$sth = ibase_query($dbh, $stmt);
while ($row = ibase_fetch_object($sth)) {
$R1 = $row->CODE;
$R2 = $row->DAYNAME;
    echo $R1." ". $R2  . "\n";
    echo "</br>";
}
ibase_close($dbh);

/**********************************************/

$host = "SERVERNAME\INSTANCENAME";
$connectionInfo = array( "Database"=>"AccessCard", "UID"=>"", "PWD"=>"");
$conn = sqlsrv_connect( $host, $connectionInfo);
if( $conn === false ) {
    die( print_r( sqlsrv_errors(), true));
}
echo "</br>"; 

for ($RIdx = 0; $RIdx < count($R1); $RIdx++) { // each $R array value

  $tsql =  "INSERT INTO [AccessCard].[dbo].[WEEKDAY] (DAYID,DAYN) VALUES ('$R1[$RIdx]','$R2[$RIdx]')"; 
  $stmt = sqlsrv_query( $conn, $tsql); 
  if ( $stmt === false )    {    
     die( print_r( sqlsrv_errors(), true));    
  }
} // end of insert loop 

sqlsrv_free_stmt( $stmt);  
sqlsrv_close( $conn);
?>

これはデータベースに表示されるものです: PIC3

4

2 に答える 2