douti0467 2017-03-16 08:36
浏览 75
已采纳

使用类中的PDO连接数据库

I have two files file1.php and database.php. I have a class 'Connection' in database.php file. I am calling this function as passing query to class 'bar'. But I am getting two errors:

1.Notice: Undefined variable: conn... on line 22
2.Fatal error: Cannot access empty property in.. on line 22

These are the codes I am using. Thank you.

file1.php

require_once('database.php');
$c = new Connection();
$c->bar("Select id, firstname, lastname from users");
$c->execute();

database.php 

class Connection{
    public $conn;

    public function __construct()
    {
        $servername = "localhost";
        $username = "root";
        $password = "";
        $dbname = "testing_pdo";
        try {
            $this->conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
            $this->conn->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
            $this->conn->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
        } catch (Exception $e) {
            echo 'ERROR: ' . $e->getMessage();
        }
    }
    public function bar($sql)
    {
        $this->conn->prepare($sql);
        return $this->conn->execute();
    }
}
  • 写回答

1条回答 默认 最新

  • douxiuar885064 2017-03-17 08:04
    关注

    I finally made it out. I made few changes in both files.

    database.php
    
    class Connection{
        private $servername = "localhost";
        private $username = "root";
        private $password = "";
        private $dbname = "testing_pdo";
    
        private $conn;
        private $error;
        private $stmt;
    
    
        public function __construct()
        {
            try {
                $this->conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
                $this->conn->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
                $this->conn->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
            } catch (Exception $e) {
                $this->error = $e->getMessage();
            }
        }
        public function bar($sql)
        {
            $this->stmt = $this->conn->prepare($sql);
        }
    
        public function resultset(){
            $this->execute();
            return $this->stmt->fetchAll(PDO::FETCH_ASSOC);
        }
    }
    
    file1.php
    
    include ('database.php');
    $c = new Connection();
    $c->bar("Select id, firstname, lastname from users");
    $c->resultset();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥200 csgo2的viewmatrix值是否还有别的获取方式
  • ¥15 Stable Diffusion,用Ebsynth utility在视频选帧图重绘,第一步报错,蒙版和帧图没法生成,怎么处理啊
  • ¥15 请把下列每一行代码完整地读懂并注释出来
  • ¥15 pycharm运行main文件,显示没有conda环境
  • ¥15 寻找公式识别开发,自动识别整页文档、图像公式的软件
  • ¥15 为什么eclipse不能再下载了?
  • ¥15 编辑cmake lists 明明写了project项目名,但是还是报错怎么回事
  • ¥15 关于#计算机视觉#的问题:求一份高质量桥梁多病害数据集
  • ¥15 特定网页无法访问,已排除网页问题
  • ¥50 如何将脑的图像投影到颅骨上