PDO的mysql数据库操作类_PHP教程

php中文网
发布: 2016-07-13 17:05:40
原创
1201人浏览过

pdo的mysql教程数据库教程操作类
* dbconfig类负责配置数据库访问信息,包括:服务器地址、端口、数据库实例名、用户名、用户密码、字符集等。
  * dbtemplate类集合了对数据库的访问操作,主要有以下几个操作:
  1. queryrows : 返回多行记录
  2. queryrow : 返回为单条记录
  3. queryforint : 查询单字段,返回整数
  4. queryforfloat : 查询单字段,返回浮点数(float)
  5. queryfordouble : 查询单字段,返回浮点数(double)
  6. queryforobject : 查询单字段,返回对象,实际类型有数据库决定
  7. update : 执行一条更新语句. insert / upadate / delete

 */

库宝AI
库宝AI

库宝AI是一款功能多样的智能伙伴助手,涵盖AI写作辅助、智能设计、图像生成、智能对话等多个方面。

库宝AI 109
查看详情 库宝AI
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始于php教程5,php6中将默认使用pdo。不同于以前版本中混乱的数据库操作方式,pdo统一了对数据库的访问方式,给编程带来了极大的便利性。本工具类就是基于pdo,模拟了java世界spring框架中的jdbctemplate操作类
 */

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/630760.htmlTechArticlepdo的mysql教程数据库教程操作类 * dbconfig类负责配置数据库访问信息,包括:服务器地址、端口、数据库实例名、用户名、用户密码、字符集...
相关标签:
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号