我有一个 Microsoft Access 数据库,我正在尝试使用 PHP 查询该表,并输出有效的 JSON。我有一个 MSSQL 数据库的等效代码,我正在尝试让我的代码做同样的事情,但只是针对 Access 数据库。
这是MSSQL代码
$myServer = "server";
$myDB = "db";
$conn = sqlsrv_connect ($myServer, array('Database'=>$myDB));
$sql = "SELECT *
FROM db.dbo.table";
$data = sqlsrv_query ($conn, $sql);
$result = array();
do {
while ($row = sqlsrv_fetch_array ($data, SQLSRV_FETCH_ASSOC)) {
$result[] = $row;
}
} while (sqlsrv_next_result($data));
$json = json_encode ($result);
sqlsrv_free_stmt ($data);
sqlsrv_close ($conn);
这是我对 MDB 文件所做的尝试
$dbName = "/filename.mdb";
if (!file_exists($dbName)) {
die("Could not find database file.");
}
$db = odbc_connect("Driver={Microsoft Access Driver (*.mdb)};Dbq=$dbName", $user, $password);
$sql = "SELECT *
FROM cemetery";
$data = $db->query($sql); // I'm getting an error here
$result = array();
// Not sure what do do for this part...
do {
while ($row = fetch($data, SQLSRV_FETCH_ASSOC)) {
$result[] = $row;
}
} while (sqlsrv_next_result($data));
$json = json_encode ($result);
我遵循此尝试连接到数据库:http://phpmaster.com/using-an-access-database-with-php/
目前,这给了我 500 内部服务器错误。我期望将这样的字符串保存在变量中$json
[
{
"col1":"col value",
"col2":"col value",
"col3":"col value",
},
{
"col1":"col value",
"col2":"col value",
"col3":"col value",
},
{
etc...
}
]
有人可以帮我移植上面的 MSSQL 代码,以便我可以将它与 MDB 数据库一起使用吗?谢谢您的帮助!
编辑:我正在逐行注释掉这些行,它在该行向我抛出 500 错误$data = $db->query($sql);
。我查看了错误日志,发现了错误Call to a member function query() on a non-object
。我已经有线路了extension=php_pdo_odbc.dll
在我的 php.ini 文件中取消注释。有人知道可能是什么问题吗?