本文实例讲述了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; } }
希望本文所述对大家的PHP程序设计有所帮助。
本文向大家介绍php使用PDO操作MySQL数据库实例,包括了php使用PDO操作MySQL数据库实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php使用PDO操作MySQL数据库的方法。分享给大家供大家参考。具体分析如下: PDO是mysql数据库操作的一个公用类,我们不需要进行自定类就可以直接使用pdo来操作数据库,但是在php默认配置中pdo是未开启所以我们必须先在php.in
本文向大家介绍PHP封装的PDO数据库操作类实例,包括了PHP封装的PDO数据库操作类实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP封装的PDO数据库操作类。分享给大家供大家参考,具体如下: 更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP基于pdo操作数据库技巧总结》、《php+Oracle数据库程序设计技巧总结》、《PHP+MongoDB数据库操作技巧大全》、《p
本文向大家介绍php pdo连接数据库操作示例,包括了php pdo连接数据库操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php pdo连接数据库操作。分享给大家供大家参考,具体如下: pdo连接数据库的有点是能实现不同数据库之间的转换,而且有事务功能的回滚,更有pdo::prepare();pdo:::execute()函数的预处理查询,所以我个人认为pdo的功能还是比较强大
本文向大家介绍php实现可用于mysql,mssql,pg数据库操作类,包括了php实现可用于mysql,mssql,pg数据库操作类的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了可用mysql,mssql,pg三种数据库的数据库操作类,你只要作任何修改就可以方便的改变你数据库的类型.分享给大家供大家参考。具体分析如下: 函数清单,索引: Open:打开数据库连接 Line:71 Clo
本文向大家介绍PHP实现PDO操作mysql存储过程示例,包括了PHP实现PDO操作mysql存储过程示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP实现PDO操作mysql存储过程。分享给大家供大家参考,具体如下: 一 代码 sql语句: index.php: 二 运行结果 数据添加成功! 更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP基于pdo操作数据库技巧总结》
本文向大家介绍Python3实现的Mysql数据库操作封装类,包括了Python3实现的Mysql数据库操作封装类的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python3实现的Mysql数据库操作封装类。分享给大家供大家参考,具体如下: 这段代码需要注意几个地方: 1.数据库配置文件变量放在类外面,只在模块被载入的时候读一次,在使用数据库类时,无需再读取。这样有一个好处就是减少了IO