php实现的pdo公共类定义与用法示例


Posted in PHP onJuly 19, 2017

本文实例讲述了php实现的pdo公共类定义与用法。分享给大家供大家参考,具体如下:

db.class.php :

<?php
class db extends \PDO {
  private static $_instance = null;
  protected $dbName = '';
  protected $dsn;
  protected $dbh;
  public function __construct($dbHost, $dbUser, $dbPasswd, $dbName, $dbCharset='utf8') {
    try {
      $this->dsn = 'mysql:host=' . $dbHost . ';dbname=' . $dbName;
      $this->dbh = new \PDO($this->dsn, $dbUser, $dbPasswd);
      $this->dbh->setAttribute(\PDO::ATTR_EMULATE_PREPARES, false);
      $this->dbh->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
      $this->dbh->exec('SET character_set_connection='.$dbCharset.';SET character_set_client='.$dbCharset.';SET character_set_results='.$dbCharset);
    } catch (Exception $e) {
      $this->outputError($e->getMessage()); 
    }
  }
  public static function getInstance($dbHost, $dbUser, $dbPasswd, $dbName, $dbCharset='utf8') {
    if (self::$_instance === null) {
      self::$_instance = new self($dbHost, $dbUser, $dbPasswd, $dbName, $dbCharset);
    }
    return self::$_instance;
  }
  public function fetchAll($sql, $params = array()) {
    try {
      $stm = $this->dbh->prepare($sql);
      if ($stm && $stm->execute($params)) {
        return $stm->fetchAll(\PDO::FETCH_ASSOC);
      }
    } catch (Exception $e) {
      $this->outputError($e->getMessage());
    }
  }
  public function fetchOne($sql, $params = array()) {
    try {
      $result = false;
      $stm = $this->dbh->prepare($sql);
      if ($stm && $stm->execute($params)) {
        $result = $stm->fetch(\PDO::FETCH_ASSOC);
      }
      return $result;
    } catch (Exception $e) {
      $this->outputError($e->getMessage());
    }
  }
  public function fetchColumn($sql, $params = array()) {
    $result = '';
    try {
      $stm = $this->dbh->prepare($sql);
      if ($stm && $stm->execute($params)) {
        $result = $stm->fetchColumn();
      }
      return $result;
    } catch (Exception $e) {
      $this->outputError($e->getMessage());
    }
  }
  public function insert($table, $params = array(), $returnLastId = true) {
    $_implode_field = '';
    $fields = array_keys($params);
    $_implode_field = implode(',', $fields);
    $_implode_value = '';
    foreach ($fields as $value) {
      $_implode_value .= ':'. $value.',';
    }
    $_implode_value = trim($_implode_value, ',');
    $sql = 'INSERT INTO ' . $table . '(' . $_implode_field . ') VALUES ('.$_implode_value.')';
    try {
      $stm = $this->dbh->prepare($sql);
      $result = $stm->execute($params);
      if ( $returnLastId ) {
        $result = $this->dbh->lastInsertId();
      }
      return $result;
    } catch (Exception $e) {
      $this->outputError($e->getMessage());
    }
  }
  public function update($table, $params = array(), $where = null) {
    $_implode_field = '';
    $_implode_field_arr = array();
    if ( empty($where) ) {
      return false;
    }
    $fields = array_keys($params);
    foreach ($fields as $key) {
      $_implode_field_arr[] = $key . '=' . ':'.$key;
    }
    $_implode_field = implode(',', $_implode_field_arr);
    $sql = 'UPDATE ' . $table . ' SET ' . $_implode_field . ' WHERE ' . $where;
    try {
      $stm = $this->dbh->prepare($sql);
      $result = $stm->execute($params);
      return $result;
    } catch (Exception $e) {
      $this->outputError($e->getMessage());
    }
  }
  public function delete($sql, $params = array()) {
    try {
      $stm = $this->dbh->prepare($sql);
      $result = $stm->execute($params);
      return $result;
    } catch (Exception $e) {
      $this->outputError($e->getMessage());
    }
  }
  public function exec($sql, $params = array()) {
    try {
      $stm = $this->dbh->prepare($sql);
      $result = $stm->execute($params);
      return $result;
    } catch (Exception $e) {
      $this->outputError($e->getMessage());
    }
  }
  private function outputError($strErrMsg) {
    throw new Exception("MySQL Error: " . $strErrMsg);
  }
  public function __destruct() {
    $this->dbh = null;
  }
}

实例:

<?php
require_once './db.class.php';
$pdo = db::getInstance('127.0.0.1', 'root', '111111', 'php_cms');
$sql = "select id, title1 from cms_wz where id = :id limit 1";
$parame = array('id' => 12,);
$res = $pdo->fetchOne($sql, $parame);
var_dump($res);
$sql = 'SELECT * FROM cms_link';
$result = $db->fetchAll($sql);
print_r($result);
//查询记录数量
$sql = 'SELECT COUNT(*) FROM cms_link';
$count = $db->fetchColumn($sql);
echo $count;
$data = array(
  'siteid' => 1,
  'linktype' => 1,
  'name' => 'google',
  'url' => 'http://www.google.com',
  'listorder' => 0,
  'elite' => 0,
  'passed' => 1,
  'addtime' => time()
  );
$lastInsertId = $db->insert('cms_link', $data);
echo $lastInsertId;
//用 try
 try {
     $result = $pdo->insert('news', $essay);
   } catch (Exception $e) {
     error_log($e->getMessage());
     error_log($e->getMessage() . ' in ' . __FILE__ . ' on line ' . __LINE__);
     saveLog('url文章 : ' . $essay['link'] . '  数据插入失败<br>');
     continue;
   }
$data = array(
  'siteid' => 1,
  'linktype' => 1,
  'name' => 'google',
  'url' => 'http://www.google.com',
  'listorder' => 0,
  'elite' => 0,
  'passed' => 1,
  'addtime' => time()
  );
$db->insert('cms_link', $data);
$sql = 'DELETE FROM cms_link WHERE linkid=4';
$result = $db->delete($sql);
var_dump($result);

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

PHP 相关文章推荐
php intval的测试代码发现问题
Jul 27 PHP
php笔记之:初探PHPcms模块开发介绍
Apr 26 PHP
php设计模式之单例、多例设计模式的应用分析
Jun 30 PHP
php使用$_POST或$_SESSION[]向js函数传参
Sep 16 PHP
PHP中imagick函数的中文解释
Jan 21 PHP
typecho插件编写教程(五):核心代码
May 28 PHP
PHP+Mysql基于事务处理实现转账功能的方法
Jul 08 PHP
php生成Android客户端扫描可登录的二维码
May 13 PHP
windows下的WAMP环境搭建图文教程(推荐)
Jul 27 PHP
PHP实现生成模糊图片的方法示例
Dec 21 PHP
windows 2008r2+php5.6.28环境搭建详细过程
Jun 18 PHP
基于PHP实现短信验证码发送次数限制
Jul 11 PHP
PHP多进程编程实例详解
Jul 19 #PHP
PHP preg_match实现正则表达式匹配功能【输出是否匹配及匹配值】
Jul 19 #PHP
php实现生成code128条形码的方法详解
Jul 19 #PHP
php-beanstalkd消息队列类实例分享
Jul 19 #PHP
php+ajax实现异步上传文件或图片功能
Jul 18 #PHP
Joomla框架实现字符串截取的方法示例
Jul 18 #PHP
PHP新特性详解之命名空间、性状与生成器
Jul 18 #PHP
You might like
PHP编程中的常见漏洞和代码实例
2014/08/06 PHP
ThinkPHP静态缓存简单配置和使用方法详解
2016/03/23 PHP
老生常谈PHP面向对象之注册表模式
2017/05/26 PHP
JavaScript高级程序设计 DOM学习笔记
2011/09/10 Javascript
JS阻止事件冒泡行为和闭包的方法
2016/06/16 Javascript
JS中将多个逗号替换为一个逗号的实现代码
2017/06/23 Javascript
vue中如何实现后台管理系统的权限控制的方法示例
2018/09/19 Javascript
简单实现vue中的依赖收集与响应的方法
2019/02/18 Javascript
浅谈react-router@4.0 使用方法和源码分析
2019/06/04 Javascript
解决Vue打包后访问图片/图标不显示的问题
2019/07/25 Javascript
nodejs制作小爬虫功能示例
2020/02/24 NodeJs
JS+css3实现幻灯片轮播图
2020/08/14 Javascript
vue+Element-ui实现分页效果
2020/11/15 Javascript
python实现可视化动态CPU性能监控
2018/06/21 Python
对python中的try、except、finally 执行顺序详解
2019/02/18 Python
利用Python实现Shp格式向GeoJSON的转换方法
2019/07/09 Python
Python类中方法getitem和getattr详解
2019/08/30 Python
python的Jenkins接口调用方式
2020/05/12 Python
Pytorch转onnx、torchscript方式
2020/05/25 Python
python语言中有算法吗
2020/06/16 Python
python import 上级目录的导入
2020/11/03 Python
Python Selenium异常处理的实例分析
2021/02/28 Python
韩国11街:11STREET
2018/03/27 全球购物
ManoMano英国:欧洲第一家专注于DIY和园艺市场的电商平台
2020/03/12 全球购物
建筑工程技术应届生自荐信
2013/09/27 职场文书
工作中个人的自我评价
2013/12/31 职场文书
安全教育感言
2014/03/04 职场文书
保证书范文大全
2014/04/28 职场文书
股指期货心得体会
2014/09/10 职场文书
银行竞聘上岗演讲稿
2014/09/12 职场文书
计划生育个人总结
2015/03/02 职场文书
2015年大学学生会工作总结
2015/05/13 职场文书
邓小平文选读书笔记
2015/06/29 职场文书
2016应届毕业生自荐信范文
2016/01/28 职场文书
高中生物教学反思
2016/02/20 职场文书
六年级作文之家庭作文
2019/12/12 职场文书