PHP实现PDO的mysql数据库操作类

2015-01-24信息快讯网

这篇文章主要介绍了PHP实现PDO的mysql数据库操作类,其中dbconfig类负责配置数据库访问信息,dbtemplate类集合了对数据库的访问操作,非常具有实用价值,需要的朋友可以参考下

本文实例讲述了PHP实现PDO的mysql数据库操作类。分享给大家供大家参考。具体分析如下:

dbconfig类负责配置数据库访问信息,包括:服务器地址、端口、数据库实例名、用户名、用户密码、字符集等.

dbtemplate类集合了对数据库的访问操作,主要有以下几个操作:

1. queryrows:返回多行记录

2. queryrow:返回为单条记录

3. queryforint:查询单字段,返回整数

4. queryforfloat:查询单字段,返回浮点数(float)

5. queryfordouble:查询单字段,返回浮点数(double)

6. queryforobject:查询单字段,返回对象,实际类型有数据库决定

7. update : 执行一条更新语句. insert / upadate / delete

具体代码如下:

class dbconfig { 
    private static $dbms = "mysql"; 
    private static $host = '127.0.0.1'; 
    private static $port = '3306'; 
    private static $username = ''; 
    private static $password = ''; 
    private static $dbname = ''; 
    private static $charset = 'utf-8'; 
    private static $dsn; 
 
    /** 
     * 
     * @return   返回pdo dsn配置 
     */ 
    public static function getdsn() { 
        if (!isset(self::$dsn)) { 
            self::$dsn = self::$dbms . ':host=' . self::$host . ';port=' . 
                    self::$port . ';dbname=' . self::$dbname; 
            if (strlen(self::$charset) > 0) { 
                self::$dsn = self::$dsn . ';charset=' . self::$charset; 
            } 
        } 
        return self::$dsn; 
    } 
 
    /** 
     * 设置mysql数据库服务器主机 
     * @param  $host 主机的ip地址 
     */ 
    public static function sethost($host) { 
        if (isset($host) && strlen($host) > 0) 
            self::$host = trim($host); 
    } 
 
    /** 
     * 设置mysql数据库服务器的端口 
     * @param  $port 端口 
     */ 
    public static function setport($port) { 
        if (isset($port) && strlen($port) > 0) 
            self::$port = trim($port); 
    } 
 
    /** 
     * 设置mysql数据库服务器的登陆用户名 
     * @param  $username 
     */ 
    public static function setusername($username) { 
        if (isset($username) && strlen($username) > 0) 
            self::$username = $username; 
    } 
 
    /** 
     * 设置mysql数据库服务器的登陆密码 
     * @param  $password 
     */ 
    public static function setpassword($password) { 
        if (isset($password) && strlen($password) > 0) 
            self::$password = $password; 
    } 
 
    /** 
     * 设置mysql数据库服务器的数据库实例名 
     * @param  $dbname 数据库实例名 
     */ 
    public static function setdbname($dbname) { 
        if (isset($dbname) && strlen($dbname) > 0) 
            self::$dbname = $dbname; 
    } 
 
    /** 
     * 设置数据库编码 
     * @param  $charset 
     */ 
    public static function setcharset($charset) { 
        if (isset($charset) && strlen($charset) > 0) 
            self::$charset = $charset; 
    } 
 
} 
 
/** 
 * 一个数据库操作工具类 
 * 
 * @author [email protected] 
 */ 
class dbtemplate { 
 
    /** 
     * 返回多行记录 
     * @param  $sql 
     * @param  $parameters 
     * @return  记录数据 
     */ 
    public function queryrows($sql, $parameters = null) { 
        return $this->exequery($sql, $parameters); 
    } 
 
    /** 
     * 返回为单条记录 
     * @param  $sql 
     * @param  $parameters 
     * @return 
     */ 
    public function queryrow($sql, $parameters = null) { 
        $rs = $this->exequery($sql, $parameters); 
        if (count($rs) > 0) { 
            return $rs[0]; 
        } else { 
            return null; 
        } 
    } 
 
    /** 
     * 查询单字段,返回整数 
     * @param  $sql 
     * @param  $parameters 
     * @return 
     */ 
    public function queryforint($sql, $parameters = null) { 
        $rs = $this->exequery($sql, $parameters); 
        if (count($rs) > 0) { 
            return intval($rs[0][0]); 
        } else { 
            return null; 
        } 
    } 
 
    /** 
     * 查询单字段,返回浮点数(float) 
     * @param  $sql 
     * @param  $parameters 
     * @return 
     */ 
    public function queryforfloat($sql, $parameters = null) { 
        $rs = $this->exequery($sql, $parameters); 
        if (count($rs) > 0) { 
            return floatval($rs[0][0]); 
        } else { 
            return null; 
        } 
    } 
 
    /** 
     * 查询单字段,返回浮点数(double) 
     * @param  $sql 
     * @param  $parameters 
     * @return 
     */ 
    public function queryfordouble($sql, $parameters = null) { 
        $rs = $this->exequery($sql, $parameters); 
        if (count($rs) > 0) { 
            return doubleval($rs[0][0]); 
        } else { 
            return null; 
        } 
    } 
 
    /** 
     * 查询单字段,返回对象,实际类型有数据库决定 
     * @param  $sql 
     * @param  $parameters 
     * @return 
     */ 
    public function queryforobject($sql, $parameters = null) { 
        $rs = $this->exequery($sql, $parameters); 
        if (count($rs) > 0) { 
            return $rs[0][0]; 
        } else { 
            return null; 
        } 
    } 
 
    /** 
     * 执行一条更新语句.insert / upadate / delete 
     * @param  $sql 
     * @param  $parameters 
     * @return  影响行数 
     */ 
    public function update($sql, $parameters = null) { 
        return $this->exeupdate($sql, $parameters); 
    } 
 
    private function getconnection() { 
        $conn = new pdo(dbconfig::getdsn(), dbconfig::getusername(), dbconfig::getpassword()); 
        $conn->setattribute(pdo::attr_case, pdo::case_upper); 
        return $conn;
    } 
 
    private function exequery($sql, $parameters = null) { 
        $conn = $this->getconnection(); 
        $stmt = $conn->prepare($sql); 
        $stmt->execute($parameters); 
        $rs = $stmt->fetchall(); 
        $stmt = null; 
        $conn = null; 
        return $rs; 
    } 
 
    private function exeupdate($sql, $parameters = null) { 
        $conn = $this->getconnection(); 
        $stmt = $conn->prepare($sql); 
        $stmt->execute($parameters); 
        $affectedrows = $stmt->rowcount(); 
        $stmt = null; 
        $conn = null; 
        return $affectedrows; 
    } 
}

pdo始于php5,php6中将默认使用pdo,不同于以前版本中混乱的数据库操作方式,pdo统一了对数据库的访问方式,给编程带来了极大的便利性,本工具类就是基于pdo,模拟了java世界spring框架中的jdbctemplate操作类.

希望本文所述对大家的PHP程序设计有所帮助。

©2014-2024 dbsqp.com