【问题标题】:Allowed memory size exhausted with odbc_exec libmdb mdbtools使用 odbc_exec libmdb mdbtools 耗尽允许的内存大小
【发布时间】:2018-11-27 11:29:32
【问题描述】:

我想通过 PHP (7.2.10)、SLE 12.3 连接到我的 MS Access 数据库。为此,我使用了 libmdbodbc1 0.7-3.1 软件包附带的 libmdbodbc.so.1 驱动程序(来源:mdbtools-0.7-3.1)。设置在 unixODBC 配置中完成: /etc/unixODBC/odbcinst.ini.

[MdbToolsOdbc]
Description = MDBTools ODBC Driver
Driver = libmdbodbc.so.1
Setup = libmdbodbc.so.1

可以通过命令行(isql)连接数据库并获取数据,并且不会返回错误。

但是当我尝试通过 PHP 执行 SQL 查询时(连接通过:odbc_connect(Driver=MdbToolsOdbc;DBQ=%s, null, null);)

odbc_exec($connection, "SELECT id FROM table");

我收到错误“允许的内存大小为 2097152 字节已用尽(尝试分配 140 字节)”。

这里还是提到了这个问题:

https://github.com/brianb/mdbtools/issues/99

https://bugs.php.net/bug.php?id=75013&thanks=3

有人知道该问题的解决方案或解决方法吗?

很高兴得到一些回应!

谢谢你,最好的!

【问题讨论】:

  • 感谢您的快速回复!我现在安装了 ibm-iaccess-1.1.0.10-1.0.x86_64.rpm。我想连接到 .mdb/.accdb MS Access-File。我怎么能设置这个?仍然尝试了“Driver={IBM i Access ODBC Driver 64-bit};Data Source=%s;System=localhost”(%s 替换为 .mdb/.accdb-File 的路径)和其他参数,但总是得到一个错误,无法建立与数据库的连接。

标签: php mdbtools


【解决方案1】:

改用 PDO: https://www.php.net/manual/en/ref.pdo-odbc.php

这适用于我使用与 Filemaker 数据库的连接。

【讨论】:

    猜你喜欢
    • 2020-06-25
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-10-21
    • 2018-08-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多