【发布时间】: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,而是要求澄清。没有人喜欢他的帮助试图浪费时间。