将数据从访问数据库插入/更新到SQL Server数据库

时间:2018-02-01 14:59:48

标签: php sql sql-server ms-access

我有一个ms访问数据库文件和一个sql server数据库。 我需要在php中编写一些东西,以便能够使用访问数据库数据更新sql数据库。更新意味着更新现有条目并插入新条目。

从访问db文件连接和获取的脚本:

<?php
$connStr = 'odbc:Driver={Microsoft Access Driver (*.mdb, *.accdb)};' .'Dbq=C:\\myfile.accdb;';
$dbh = new PDO($connStr);
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$sql = "SELECT ID, `LAST NAME` AS lm, `FIRST NAME` AS fm,  FROM OLD";
$sql .= " UNION ALL SELECT ID, `Last Name` AS lm, `First Name` AS fm,  FROM NEW) ";
$sql .= " ORDER BY lm";

$sth = $dbh->prepare($sql);
$params = array();
$sth->execute($params);

while ($row = $sth->fetch()) {
//do something with $row['lm'] and $row['fm']
}
?>

从sql db文件连接和获取的脚本:

<?php
$sql = "SELECT * FROM MYTABLE";
$stmt = sqlsrv_query($conn, $sql);
if($stmt === false) {
    echo 'Error. Could not execute query!';  
}

while ($rowsec = sqlsrv_fetch_array($stmt, SQLSRV_FETCH_ASSOC)) {
     //do something with $rowsec['MYTABLE_COLUMN']
?>

那么,我如何组合这两个查询以便从访问文件中获取数据并从sql表中插入/更新记录?

假设当我在更新/插入sql表之前从访问文件中读取数据时,我需要检查访问文件中的列并修改如下:

<?php 
if($row['fm'].indexOf('am') > -1) {$id = 'am'.$row['ID']}
?> 

然后我应该在$ row [&#39; lm&#39;]和$ row [&#39; fm&#39;]值中使用$ id来插入/更新到sql数据库。

提前谢谢

1 个答案:

答案 0 :(得分:0)

如上所述,如果允许用户使用ad-hoc分布式查询权限并考虑使用相同的ODBC连接驱动程序在结果集之间进行任何循环,请考虑使用SQL Server的OPENROWSET

INSERT QUERY

INSERT INTO MYTABLE (ID, LM, FM)
SELECT t.*
FROM (SELECT ID, [LAST NAME] AS lm, [FIRST NAME] AS fm  
      FROM OPENROWSET('MSDASQL',
                      'Driver={Microsoft Access Driver (*.mdb, *.accdb)};
                       DBQ=C:\\myfile.accdb', 'SELECT * FROM [OLD]')

      UNION ALL 

      SELECT ID, [LAST NAME] AS lm, [FIRST NAME] AS fm  
      FROM OPENROWSET('MSDASQL',
                      'Driver={Microsoft Access Driver (*.mdb, *.accdb)};
                       DBQ=C:\\myfile.accdb', 'SELECT * FROM [New]')
     ) t
WHERE NOT EXISTS (SELECT 1 FROM MYTABLE s WHERE s.ID = t.ID)
ORDER BY t.LM

更新查询

UPDATE t
SET t.Lm = n.lm, t.Fm = n.fm
FROM MYTABLE t
INNER JOIN 
    (SELECT ID, [LAST NAME] AS lm, [FIRST NAME] AS fm  
     FROM OPENROWSET('MSDASQL',
                     'Driver={Microsoft Access Driver (*.mdb, *.accdb)};
                      DBQ=C:\\myfile.accdb', 'SELECT * FROM [OLD]')

     UNION ALL 

     SELECT ID, [LAST NAME] AS lm, [FIRST NAME] AS fm  
     FROM OPENROWSET('MSDASQL',
                     'Driver={Microsoft Access Driver (*.mdb, *.accdb)};
                      DBQ=C:\\myfile.accdb', 'SELECT * FROM [New]')
    ) n
ON t.ID = n.ID

或者,使用ACE OLEDB Provider:

FROM OPENROWSET('Microsoft.ACE.OLEDB.12.0',   
   'C:\\myfile.accdb';'admin';'', Old)

确保在PHP查询字符串中加倍单引号(类似于加倍\)。