我有一个 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 文件中已取消注释该行。任何人都知道问题可能是什么?