PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】


Posted in PHP onMay 21, 2018

本文实例讲述了PHP基于pdo的数据库操作类。分享给大家供大家参考,具体如下:

工作中需要操作sqlserver、oracle都是使用的这个类,当时是在别人的基础上改进了,现在分享下

<?php
class Pdodb{
  protected $pdo;
  protected $res;
  protected $config;
  /*构造函数*/
  function __construct($config){
    $this->Config = $config;
    $this->connect();
  }
  /*数据库连接*/
  public function connect(){
    try {
       $this->pdo= new PDO($this->Config['dsn'], $this->Config['username'], $this->Config['password']);//$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
       $this->pdo->query("set names utf8");
    }catch(Exception $e){
      echo '数据库连接失败,详情: ' . $e->getMessage () . ' 请在配置文件中数据库连接信息';
      exit ();
    }
    /*
    if($this->Config['type']=='oracle'){
      $this->pdo->query("set names {$this->Config['charset']};");
    }else{
      $this->pdo->query("set names {$this->Config['charset']};");
    }
    */
    //把结果序列化成stdClass
    //$this->pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_OBJ);
    //自己写代码捕获Exception
    //$this->pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $this->pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);//属性名 属性值 数组以关联数组返回
  }
  /*数据库关闭*/
  public function close(){
    $this->pdo = null;
  }
  //用于有记录结果返回的操作,特别是SELECT操作
  public function query($sql,$return=false){
    $res = $this->pdo->query($sql);
    if($res){
      $this->res = $res; // 未返回 return $this->res;
    }
    if($return){
      return $res;
    }
  }
  //主要是针对没有结果集合返回的操作,比如INSERT、UPDATE、DELETE等操作
  public function exec($sql,$return=false){
    $res = $this->pdo->exec($sql);
    if($res){
      $this->res = $res;
    }
    if($return){//返回操作是否成功 成功返回1 失败0
      return $res;
    }
  }
  //将$this->res以数组返回(全部返回)
  public function fetchAll(){
    return $this->res->fetchAll();
  }
  //将$this->res以数组返回(一条记录)
  public function fetch(){
    return $this->res->fetch();
  }
  //返回所有字段
  public function fetchColumn(){
    return $this->res->fetchColumn();
  }
  //返回最后插入的id
  public function lastInsertId(){
    return $this->res->lastInsertId();
  }
  //返回最后插入的id
  public function lastInsertId2(){
    return $this->pdo->lastInsertId();
  }
  /**
  * 参数说明
  * string/array $table 数据库表,两种传值模式
  * 普通模式:
  * 'tb_member, tb_money'
  * 数组模式:
  * array('tb_member', 'tb_money')
  * string/array $fields 需要查询的数据库字段,允许为空,默认为查找全部,两种传值模式
  * 普通模式:
  * 'username, password'
  * 数组模式:
  * array('username', 'password')
  * string/array $sqlwhere 查询条件,允许为空,两种传值模式
  * 普通模式(必须加上and,$sqlwhere为空 1=1 正常查询):
  * 'and type = 1 and username like "%os%"'
  * 数组模式:
  * array('type = 1', 'username like "%os%"')
  * string $orderby 排序,默认为id倒序
  *int $debug 是否开启调试,开启则输出sql语句
  * 0 不开启
  * 1 开启
  * 2 开启并终止程序
  * int $mode 返回类型
  * 0 返回多条记录
  * 1 返回单条记录
  * 2 返回行数
  */
  public function select($table, $fields="*", $sqlwhere="", $orderby="", $debug=0, $mode=0){
    //参数处理
    if(is_array($table)){
      $table = implode(', ', $table);
    }
    if(is_array($fields)){
      $fields = implode(',',$fields);
      /*
      if($this->Config['type']=='oracle'){
        //$fields = implode(',',$fields);//CUSTOMER_ID,FIRST_NAME,LAST_NAME,EMAIL
        //$fields = implode(",'UTF8','ZHS16GBK') ,convert(",$fields);
        //$fields="convert(".$fields.",'UTF8','ZHS16GBK')";
      }else{
        $fields = implode(',',$fields);
      }
      */
    }
    if(is_array($sqlwhere)){
      $sqlwhere = ' and '.implode(' and ', $sqlwhere);
    }
    //数据库操作
    if($debug === 0){
      if($mode === 2){ //统计
        $this->query("select count(*) from $table where 1=1 $sqlwhere");
        $return = $this->fetchColumn();
      }else if($mode === 1){ //返回一条
        $this->query("select $fields from $table where 1=1 $sqlwhere $orderby");
        $return = $this->fetch();
      }else{
        $this->query("select $fields from $table where 1=1 $sqlwhere $orderby");
        $return = $this->fetchAll();//如果 $this->res为空即sql语句错误 会提示Call to a member function fetchAll() on a non-object
      }
      return $return;
    }else{
        if($mode === 2){
          echo "select count(*) from $table where 1=1 $sqlwhere";
        }else if($mode === 1){
          echo "select $fields from $table where 1=1 $sqlwhere $orderby";
        }else{
          echo "select $fields from $table where 1=1 $sqlwhere $orderby";
        }
        if($debug === 2){
          exit;
        }
    }
  }
  /**
  * 参数说明
  * string/array $table 数据库表,两种传值模式
  * 普通模式:
  * 'tb_member, tb_money'
  * 数组模式:
  * array('tb_member', 'tb_money')
  * string/array $set 需要插入的字段及内容,两种传值模式
  * 普通模式:
  * 'username = "test", type = 1, dt = now()'
  * 数组模式:
  * array('username = "test"', 'type = 1', 'dt = now()')
  * int $debug 是否开启调试,开启则输出sql语句
  * 0 不开启
  * 1 开启
  * 2 开启并终止程序
  * int $mode 返回类型
  * 0 无返回信息
  * 1 返回执行条目数
  * 2 返回最后一次插入记录的id
  */
  public function oic_insert($table, $set, $debug=0, $mode=0){
    //参数处理
    if(is_array($table)){
      $table = implode(', ', $table);
    }
    if(is_array($set)){
      $s='';$i=0;
      foreach($set as $k=>$v){
        $i++;
        $s[$i]=$k;//,连接
        $val[$i]=$v;
      }
      $sarr=implode(",",$s);//去掉最后一个,
      //array_pop($sarr);
      $set=implode("','",$val);////15221579236','张三','','2001','8','4','女','是
      //$set = implode(', ', $set);
    }
    //数据库操作
    if($debug === 0){
      if($mode === 2){
        $this->query("insert into $table ($sarr) values('".$set."')");
        //$return = $this->lastInsertId();
      }else if($mode === 1){
        $this->exec("insert into $table ($sarr) values('".$set."')");
        $return = $this->res;
      }else{
        $this->query("insert into $table ($sarr) values('".$set."')");
        $return = NULL;
      }
      return $return;
    }else{
      echo "insert into $table ($sarr) values('".$set."')";
      if($debug === 2){
        exit;
      }
    }
  }
  public function insert($table, $set, $debug=0, $mode=0){
    //参数处理
    if(is_array($table)){
      $table = implode(', ', $table);
    }
    if(is_array($set)){
      $s='';
      foreach($set as $k=>$v){
        $s.=$k."='".$v."',";//,连接
      }
      $sarr=explode(',',$s);//去掉最后一个,
      array_pop($sarr);
      $set=implode(',',$sarr);
      //$set = implode(', ', $set);
    }
    //数据库操作
    if($debug === 0){
      if($mode === 2){
        $this->query("insert into $table set $set");
        $return = $this->pdo->lastInsertId();
      }else if($mode === 1){
        $this->exec("insert into $table set $set");
        $return = $this->res;
      }else{
        $this->query("insert into $table set $set");
        $return = NULL;
      }
      return $return;
    }else{
      echo "insert into $table set $set";
      if($debug === 2){
        exit;
      }
    }
  }
  /**
  * 参数说明
  * string $table 数据库表,两种传值模式
  * 普通模式:
  * 'tb_member, tb_money'
  * 数组模式:
  * array('tb_member', 'tb_money')
  * string/array $set 需要更新的字段及内容,两种传值模式
  * 普通模式:
  * 'username = "test", type = 1, dt = now()'
  * 数组模式:
  * array('username = "test"', 'type = 1', 'dt = now()')
  * string/array $sqlwhere 修改条件,允许为空,两种传值模式
  * 普通模式:
  * 'and type = 1 and username like "%os%"'
  * 数组模式:
  * array('type = 1', 'username like "%os%"')
  * int $debug 是否开启调试,开启则输出sql语句
  * 0 不开启
  * 1 开启
  * 2 开启并终止程序
  * int $mode 返回类型
  * 0 无返回信息
  * 1 返回执行条目数
  */
  public function update($table, $set, $sqlwhere="", $debug=0, $mode=0){
    //参数处理
    if(is_array($table)){
      $table = implode(', ', $table);
    }
    if(is_array($set)){
      $s='';
      foreach($set as $k=>$v){
        $s.=$k."='".$v."',";
      }
      $sarr=explode(',',$s);//去掉最后一个,
      array_pop($sarr);
      $set=implode(',',$sarr);
      //$set = implode(', ', $set);
    }
    if(is_array($sqlwhere)){
      $sqlwhere = ' and '.implode(' and ', $sqlwhere);
    }
    //数据库操作
    if($debug === 0){
      if($mode === 1){
        $this->exec("update $table set $set where 1=1 $sqlwhere");
        $return = $this->res;
      }else{
        $this->query("update $table set $set where 1=1 $sqlwhere");
        $return = true;
      }
      return $return;
    }else{
      echo "update $table set $set where 1=1 $sqlwhere";
      if($debug === 2){
        exit;
      }
    }
  }
  /**
  * 参数说明
  * string $table 数据库表
  * string/array $sqlwhere 删除条件,允许为空,两种传值模式
  * 普通模式:
  * 'and type = 1 and username like "%os%"'
  * 数组模式:
  * array('type = 1', 'username like "%os%"')
  * int $debug 是否开启调试,开启则输出sql语句
  * 0 不开启
  * 1 开启
  * 2 开启并终止程序
  * int $mode 返回类型
  * 0 无返回信息
  * 1 返回执行条目数
  */
  public function delete($table, $sqlwhere="", $debug=0, $mode=0){
    //参数处理
    if(is_array($sqlwhere)){
      $sqlwhere = ' and '.implode(' and ', $sqlwhere); //是字符串需自己加上and
    }
    //数据库操作
    if($debug === 0){
      if($mode === 1){
        $this->exec("delete from $table where 1=1 $sqlwhere");
        $return = $this->res;
      }else{
        $this->query("delete from $table where 1=1 $sqlwhere");
        $return = NULL;
      }
      return $return;
    }else{
      echo "delete from $table where 1=1 $sqlwhere";
      if($debug === 2){
        exit;
      }
    }
  }
}
/*
sqlserver 配置 extension=php_pdo_mssql.dll和extension=php_pdo_sqlsrv.dll 安装对应的 ntwdblib.dll
http://msdn.microsoft.com/en-us/library/cc296170.aspx 下载php版本对应的sqlsrv扩展
sqlserver 配置 odbc连接需开启extension=php_pdo_odbc.dll
*/
$mssql2008_config=array(
  'dsn'=>'odbc:Driver={SQL Server};Server=192.168.1.60;Database=his',//数据库服务器地址
  'username'=>'sa',
  'password'=>'xxxxx',
);
$mssql=new Pdodb($mssql2008_config);
$sql="select * from
(
  select row_number()over(order by tempcolumn)temprownumber,*
    from (
      select top 10 tempcolumn=0,a.*
      from DA_GR_HBFS a
      where 1=1
    ) t
) tt
where temprownumber>0";
$mssql->query($sql);
while($res=$mssql->fetch()){
  $data[]=$res;
}
print_r($data);exit;
//mysql 操作
$msyql_config=array(
  'dsn'=>'mysql:host=localhost;dbname=talk',
  'username'=>'root',
  'password'=>'123456'
);
$mysql=new PDO_DB($msyql_config);
$sql = 'SELECT user_id, user_name, nickname FROM et_users ';
$mysql->query($sql);
$data=$mysql->fetchAll();
print_r($data);exit;
//oracle 操作
$oci_config=array(
  'dsn'=>'oci:dbname=orcl',
  'username'=>'BAOCRM',
  'password'=>'BAOCRM'
);
$oracle=new PDO_DB($oci_config);
//print_r($oracle);exit;//PDO_DB Object ( [pdo:protected] => PDO Object ( ) [res:protected] => [config:protected] => [Config] => Array ( [dsn] => oci:dbname=orcl [name] => PWACRM [password] => PWACRM ) )
$sql="select * from CUSTOMER_LEVEL t";
$oracle->query($sql);
$data=$oracle->fetchAll();
print_r($data);exit;
/*
Array
(
  [0] => Array
    (
      [LEVEL_ID] => 1
      [0] => 1
      [LEVEL_NAME] => 普通会员
      [1] => 普通会员
      [LEVEL_DETAIL] => 普通会员
      [2] => 普通会员
      [SORT_NUMBER] => 15
      [3] => 15
      [CREATE_TIME] => 12-7月 -12
      [4] => 12-7月 -12
      [CREATE_BY] => 1
      [5] => 1
      [UPDATE_TIME] => 12-7月 -12
      [6] => 12-7月 -12
      [UPDATE_BY] => 1
      [7] => 1
      [STATE] => 正常
      [8] => 正常
    )
)*/
?>

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

PHP 相关文章推荐
PHP几个数学计算的内部函数学习整理
Aug 06 PHP
openPNE常用方法分享
Nov 29 PHP
php木马webshell扫描器代码
Jan 25 PHP
PHP生成sitemap.xml地图函数
Nov 13 PHP
PHP把网页保存为word文件的三种方法
Apr 01 PHP
PHP利用MySQL保存session的实现思路及示例代码
Sep 09 PHP
PHP产生不重复随机数的5个方法总结
Nov 12 PHP
PHP中定义数组常量(array常量)的方法
Nov 17 PHP
php实现处理输入转义字符的代码
Nov 08 PHP
超详细的php用户注册页面填写信息完整实例(附源码)
Nov 17 PHP
PHP读书笔记整理_结构语句详解
Jul 01 PHP
PHP+Apache实现二级域名之间共享cookie的方法
Jul 24 PHP
PHP+MariaDB数据库操作基本技巧备忘总结
May 21 #PHP
PhpStorm本地断点调试的方法步骤
May 21 #PHP
PHP自动识别当前使用移动终端
May 21 #PHP
PHP连接MySQL数据库并以json格式输出
May 21 #PHP
PHP 访问数据库配置通用方法(json)
May 20 #PHP
PHP生成腾讯云COS接口需要的请求签名
May 20 #PHP
windows环境下使用Composer安装ThinkPHP5
May 18 #PHP
You might like
PHP 出现乱码和Sessions验证问题的解决方法!
2008/12/06 PHP
用来解析.htpasswd文件的PHP类
2012/09/05 PHP
浅析THINKPHP的addAll支持的最大数据量
2015/02/03 PHP
php制作基于xml的RSS订阅源功能示例
2017/02/08 PHP
php中Swoole的热更新实现代码实例
2021/03/04 PHP
javascript 一段左右两边随屏滚动的代码
2009/06/18 Javascript
Prototype源码浅析 String部分(四)之补充
2012/01/16 Javascript
Js,alert出现乱码问题的解决方法
2013/06/19 Javascript
jquery使用$(element).is()来判断获取的tagName
2014/08/24 Javascript
JavaScript阻止事件冒泡示例分享
2014/12/28 Javascript
全面解析Bootstrap表单使用方法(表单样式)
2015/11/24 Javascript
KnockoutJS 3.X API 第四章之数据控制流foreach绑定
2016/10/10 Javascript
最常见和最有用的字符串相关的方法详解
2017/02/06 Javascript
Vue2.0基于vue-cli+webpack Vuex的用法(实例讲解)
2017/09/15 Javascript
浅析Vue中method与computed的区别
2018/03/06 Javascript
node基于puppeteer模拟登录抓取页面的实现
2018/05/09 Javascript
利用nodeJs anywhere搭建本地服务器环境的方法
2018/05/12 NodeJs
微信小程序实现人脸识别
2018/05/25 Javascript
vuejs使用axios异步访问时用get和post的实例讲解
2018/08/09 Javascript
Vue 封装防刷新考试倒计时组件的实现
2020/06/05 Javascript
解决Django模板无法使用perms变量问题的方法
2017/09/10 Python
Python之列表的插入&amp;替换修改方法
2018/06/28 Python
Python并发之多进程的方法实例代码
2018/08/15 Python
浅谈python中拼接路径os.path.join斜杠的问题
2018/10/23 Python
Python脚本破解压缩文件口令实例教程(zipfile)
2020/06/14 Python
python中strip(),lstrip(),rstrip()函数的使用讲解
2020/11/17 Python
Python之字符串的遍历的4种方式
2020/12/08 Python
利用Canvas模仿百度贴吧客户端loading小球的方法示例
2017/08/13 HTML / CSS
英国乐购杂货:Tesco Groceries
2018/11/29 全球购物
毕业生求职简历中的自我评价
2013/10/18 职场文书
《自选商场》教学反思
2014/02/14 职场文书
大学学习个人的自我评价
2014/02/18 职场文书
水电工岗位职责
2015/02/14 职场文书
《酸的和甜的》教学反思
2016/02/18 职场文书
python ConfigParser库的使用及遇到的坑
2022/02/12 Python
三星 3nm 芯片将于第二季度开始量产
2022/04/29 数码科技