【问题标题】:PHP: Debugging PDO connection to Access database (.accdb)PHP:调试与 Access 数据库 (.accdb) 的 PDO 连接
【发布时间】:2014-09-02 23:06:59
【问题描述】:

我是编程新手,想使用 PDO 类连接到 ms-access (accdb) 数据库。 环境:PHP (5.5.11) / XAMPP / Windows 7 pro。已启用 ODBC (win32) 的 PDO 驱动程序。

class db{
  protected $dbName = "C:\xampp\htdocs\BillboardsManagement\Core\config\Billboards.accdb";
  protected $Uid="";
  protected $Upass="";
  protected $conn;

  public function __construct() {
    try{
        $this -> conn = new PDO('odbc:DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=$this->$dbName;Uid=$this->$Uid;Pwd=$this->$Upass');
    } catch (Exception $e) {
        echo "\n $e-> getMessage()\n";   
    }
  }
}

当我尝试实例化类时,出现以下错误:

带有消息“SQLSTATE[IM002]”的异常“PDOException” SQLDriverConnect: 0 [Microsoft][ODBC Driver Manager] 数据源名称 未找到且未指定默认驱动程序 C:\xampp\htdocs\BillboardsManagement\Core\config\config.php:13 堆栈 跟踪:#0 C:\xampp\htdocs\BillboardsManagement\Core\config\config.php(13): PDO->__construct('odbc:DRIVER={Mi...') #1 C:\xampp\htdocs\BillboardsManagement\Views\selectBB.php(3): db->__construct() #2 {main}-> getMessage() 致命错误:调用 非对象上的成员函数 prepare() C:\xampp\htdocs\BillboardsManagement\Core\classes\bbClasses.php 上 第 11 行

提前感谢您的帮助。

更新:我知道以前回答过类似的问题。但我正处于学习过程中。上一篇文章的答案是使用 adodb 而不是 PDO(出于我完全同意的原因),但我仍然很好奇在我的特定情况下出了什么问题。我仍然无法确定我的代码是否有问题,或者是一些 odbc 驱动程序或配置问题。

【问题讨论】:

  • 我已经将我之前的评论移动并扩展为自己的答案,因为它显然不够清楚。但请不要忽略您不理解的 cmets,而是要求澄清。没有人喜欢他的帮助试图浪费时间。

标签: php ms-access pdo odbc


【解决方案1】:

经过大量阅读,我发现我使用了错误版本的Microsoft Access Database Engine:64 位版本没有 *.accdb 格式的 32 位驱动程序。

再次感谢您的启发性支持。

【讨论】:

  • 我在使用@Phil 时遇到了同样的问题,但我使用的是 64 位的 wampserver3,我只是卸载了 64 位并安装了 32 位的 wampserver,它现在可以正常工作了。
【解决方案2】:

您在此字符串中提供连接详细信息:

'odbc:DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=$this->$dbName;Uid=$this->$Uid;Pwd=$this->$Upass'

如果我们检查how strings work in PHP,我们可以阅读关于我们的单引号字符串:

与双引号和heredoc语法不同,变量和转义 特殊字符的序列在出现时不会被扩展 在单引号字符串中。

所以 PHP 将尝试打开一个名为 $this->$dbName 的文件,字面意思。因此,首先,您可能需要以下语法之一:

  • 双引号字符串:"File name $foo blah"
  • 连接:'File name ' . $foo . ' blah'

现在,您想从对象属性中读取文件名:

protected $dbName = "C:\xampp\htdocs\BillboardsManagement\Core\config\Billboards.accdb";

manual explains的语法是:

$this->dbName

但是,你有这个:

$this->$dbName

一旦您解决了这个问题,最好验证您的变量是否包含您认为它们所做的事情。为此,我推荐var_dump()

$connection_string = 'odbc:DRIVER={Microsoft ....';
var_dump($connection_string);

值得注意的是,我所解释的一切都与基本的 PHP 语法有关。到目前为止,PDO 和 Access 问题都没有出现。它总是有助于隔离您的问题。

【讨论】:

  • 非常感谢您的 cmets 和详细的帮助,我无意让您相信您在浪费时间,对此我感到非常抱歉。按照您的建议,我越来越相信这是 odbc 驱动程序问题。我只是在 64 位平台上找不到 accdb 数据库的 32 位驱动程序。
猜你喜欢
  • 2015-01-16
  • 1970-01-01
  • 1970-01-01
  • 2011-09-17
  • 2011-01-23
  • 2013-05-14
  • 2021-12-06
  • 2020-04-29
  • 1970-01-01
相关资源
最近更新 更多