-
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;//开源代码phpfensi.com
- }
- 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操作类.
出处:http://www.phpfensi.com/php/20140911/5352.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式