Usando PHP para consultar um arquivo MDB e retornar JSON
Eu tenho um banco de dados do Microsoft Access e estou tentando consultar a tabela usando PHP e saída JSON válido. Eu tenho um código equivalente para um banco de dados MSSQL, estou tentando fazer o meu código fazer a mesma coisa, mas apenas para o banco de dados do Access.
Aqui está o código 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);
Aqui está o que eu tentei para o arquivo 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);
Eu meio que segui isso para tentar se conectar ao banco de dados:http://phpmaster.com/using-an-access-database-with-php/
Atualmente isso está me dando um 500 Internal Server Error. Eu estou esperando uma string como esta para ser salvo na variável$json
[
{
"col1":"col value",
"col2":"col value",
"col3":"col value",
},
{
"col1":"col value",
"col2":"col value",
"col3":"col value",
},
{
etc...
}
]
Alguém pode me ajudar a portar o código MSSQL que eu tenho acima para que eu possa usá-lo com um banco de dados MDB? Obrigado pela ajuda!
EDIT: estou comentando as linhas, um por um, e isso me lança o erro 500 na linha$data = $db->query($sql);
. Eu olhei no log de erros e estou recebendo o erroCall to a member function query() on a non-object
. Eu já tenho a linhaextension=php_pdo_odbc.dll
descomentei no meu arquivo php.ini. Alguém sabe o que o problema poderia ser?