91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在PHP中利用PDO實現一個mysql數據庫操作類

發布時間:2020-12-15 17:21:53 來源:億速云 閱讀:159 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關如何在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 zhjiun@gmail.com 
 */ 
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中利用PDO實現一個mysql數據庫操作類了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

枞阳县| 延津县| 贵定县| 探索| 广安市| 鹤庆县| 师宗县| 平舆县| 武夷山市| 扎兰屯市| 安康市| 门源| 怀集县| 武威市| 深泽县| 芮城县| 休宁县| 安吉县| 新巴尔虎右旗| 镇远县| 松潘县| 西充县| 东莞市| 长岛县| 灌南县| 麦盖提县| 阿克苏市| 四会市| 四子王旗| 新营市| 宜春市| 万山特区| 兰西县| 石棉县| 阿拉善左旗| 万荣县| 扶沟县| 日土县| 峨边| 山西省| 揭西县|