0

我知道 CI 2.1.3 现在支持 PDO。但是使用 pdo 函数而不是 codeigniter 函数对我来说会更舒服,现在我想扩展 PDO 并将其用作库并在控制器或其他库加载后创建 PDO 对象;这是可能的,不是吗?到目前为止我的尝试:

class Mypdo extends PDO {
  public function __construct($dsn='mysql:dbname=mydbname;host=localhost',
                              $username='myusername',
                              $password='mypassword',
                              $driver_options=array()) {
        parent::__construct($dsn, $username, $password, $driver_options);
  }
}

和简单的用法:

class Otherlibrary{
   var $CI;
   var $something_id;

   public function __construct(){
      $this->CI =& get_instance();
      $this->CI->load->library('mypdo');

      $this->something_id = 'foo';
   }

   public function is_something_exist(){
      try{
         $q = "SELECT * FROM something WHERE something_id = '$this->something_id'";
         $stmt = $this->CI->mypdo->prepare($q); //<--PROBLEM
         $stmt->execute();

         if ($stmt->rowCount() < 1){
            return false;
          } else {
            return true;
          }
       } catch (PDOException $e){
           echo $e->getMessage();
       }
    }
}

总是返回:

致命错误:在...中的非对象上调用成员函数 prepare()

我根本不是 PHP 类/对象方面的专家,所以我需要帮助来改进我的代码并使其正常工作。谢谢。

4

1 回答 1

0

根据 CodeIgniter库文档

  • 文件名必须大写。例如:Myclass.php 类

  • 声明必须大写。例如:类 Myclass

  • 类名和文件名必须匹配。

确保您的 Mypdo 类是 application/library/Mypdo.php。

于 2013-04-09T03:50:41.450 回答