0

0

php-mysql的封装类

PHP中文网

PHP中文网

发布时间:2016-05-26 08:18:56

|

1379人浏览过

|

来源于php中文网

原创

_host = $conf['host'];
$this->_port = $conf['port'];
$this->_user = $conf['user'];
$this->_pass = $conf['passwd'];
$this->_dbName = $conf['dbname'];
//连接数据库
       if ( is_null(self::$_dbh) ) {
           $this->_connect();
       }
   }
/**
    * 连接数据库的方法
    */
protected function _connect() {
$dsn = $this->_dbType.':host='.$this->_host.';port='.$this->_port.';dbname='.$this->_dbName;
$options = $this->_pconnect ? array(PDO::ATTR_PERSISTENT=>true) : array();
try { 
$dbh = new PDO($dsn, $this->_user, $this->_pass, $options);
           $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);  //设置如果sql语句执行错误则抛出异常,事务会自动回滚
           $dbh->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); //禁用prepared statements的仿真效果(防SQL注入)
} catch (PDOException $e) { 
           die('Connection failed: ' . $e->getMessage());
}
$dbh->exec('SET NAMES utf8');
self::$_dbh = $dbh;
}
   /** 
   * 字段和表名添加 `符号
   * 保证指令中使用关键字不出错 针对mysql 
   * @param string $value 
   * @return string 
   */ 
   protected function _addChar($value) { 
       if ('*'==$value || false!==strpos($value,'(') || false!==strpos($value,'.') || false!==strpos($value,'`')) { 
           //如果包含* 或者 使用了sql方法 则不作处理 
       } elseif (false === strpos($value,'`') ) { 
           $value = '`'.trim($value).'`';
       } 
       return $value; 
   }
   /** 
   * 取得数据表的字段信息 
   * @param string $tbName 表名
   * @return array 
   */ 
   protected function _tbFields($tbName) {
       $sql = 'SELECT COLUMN_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME="'.$tbName.'" AND TABLE_SCHEMA="'.$this->_dbName.'"';
       $stmt = self::$_dbh->prepare($sql);
       $stmt->execute();
       $result = $stmt->fetchAll(PDO::FETCH_ASSOC);
       $ret = array();
       foreach ($result as $key=>$value) {
           $ret[$value['COLUMN_NAME']] = 1;
       }
       return $ret;
   }
   /** 
   * 过滤并格式化数据表字段
   * @param string $tbName 数据表名 
   * @param array $data POST提交数据 
   * @return array $newdata 
   */
   protected function _dataFormat($tbName,$data) {
       if (!is_array($data)) return array();
       $table_column = $this->_tbFields($tbName);
       $ret=array();
       foreach ($data as $key=>$val) {
           if (!is_scalar($val)) continue; //值不是标量则跳过
           if (array_key_exists($key,$table_column)) {
               $key = $this->_addChar($key);
               if (is_int($val)) { 
                   $val = intval($val); 
               } elseif (is_float($val)) { 
                   $val = floatval($val); 
               } elseif (preg_match('/^\(\w*(\+|\-|\*|\/)?\w*\)$/i', $val)) {
                   // 支持在字段的值里面直接使用其它字段 ,例如 (score+1) (name) 必须包含括号
                   $val = $val;
               } elseif (is_string($val)) { 
                   $val = '"'.addslashes($val).'"';
               }
               $ret[$key] = $val;
           }
       }
       return $ret;
   }
   
   /**
   * 执行查询 主要针对 SELECT, SHOW 等指令
   * @param string $sql sql指令 
   * @return mixed 
   */ 
   protected function _doQuery($sql='') {
       $this->_sql = $sql;
       $pdostmt = self::$_dbh->prepare($this->_sql); //prepare或者query 返回一个PDOStatement
       $pdostmt->execute();
       $result = $pdostmt->fetchAll(PDO::FETCH_ASSOC);
       return $result;
   }
   
   /** 
   * 执行语句 针对 INSERT, UPDATE 以及DELETE,exec结果返回受影响的行数
   * @param string $sql sql指令 
   * @return integer 
   */ 
   protected function _doExec($sql='') {
       $this->_sql = $sql;
       return self::$_dbh->exec($this->_sql);
   }
   /** 
   * 执行sql语句,自动判断进行查询或者执行操作 
   * @param string $sql SQL指令 
   * @return mixed 
   */ 
   public function doSql($sql='') {
       $queryIps = 'INSERT|UPDATE|DELETE|REPLACE|CREATE|DROP|LOAD DATA|SELECT .* INTO|COPY|ALTER|GRANT|REVOKE|LOCK|UNLOCK'; 
       if (preg_match('/^\s*"?(' . $queryIps . ')\s+/i', $sql)) { 
           return $this->_doExec($sql);
       }
       else {
           //查询操作
           return $this->_doQuery($sql);
       }
   }
   /** 
   * 获取最近一次查询的sql语句 
   * @return String 执行的SQL 
   */ 
   public function getLastSql() { 
       return $this->_sql;
   }
   /**
    * 插入方法
    * @param string $tbName 操作的数据表名
    * @param array $data 字段-值的一维数组
    * @return int 受影响的行数
    */
   public function insert($tbName,array $data){
       $data = $this->_dataFormat($tbName,$data);
       if (!$data) return;
       $sql = "insert into ".$tbName."(".implode(',',array_keys($data)).") values(".implode(',',array_values($data)).")";
return $this->_doExec($sql);
   }
   /**
    * 删除方法
    * @param string $tbName 操作的数据表名
    * @return int 受影响的行数
    */
   public function delete($tbName) {
       //安全考虑,阻止全表删除
       if (!trim($this->_where)) return false;
       $sql = "delete from ".$tbName." ".$this->_where;
       $this->_clear = 1;
       $this->_clear();
       return $this->_doExec($sql);
   }
   /**
    * 更新函数
    * @param string $tbName 操作的数据表名
    * @param array $data 参数数组
    * @return int 受影响的行数
    */
   public function update($tbName,array $data) {
       //安全考虑,阻止全表更新
       if (!trim($this->_where)) return false;
       $data = $this->_dataFormat($tbName,$data);
       if (!$data) return;
       $valArr = '';
       foreach($data as $k=>$v){
           $valArr[] = $k.'='.$v;
       }
       $valStr = implode(',', $valArr);
       $sql = "update ".trim($tbName)." set ".trim($valStr)." ".trim($this->_where);
       return $this->_doExec($sql);
   }
   /**
    * 查询函数
    * @param string $tbName 操作的数据表名
    * @return array 结果集
    */
   public function select($tbName='') {
       $sql = "select ".trim($this->_field)." from ".$tbName." ".trim($this->_where)." ".trim($this->_order)." ".trim($this->_limit);
       $this->_clear = 1;
       $this->_clear();
       return $this->_doQuery(trim($sql));
   }
   /**
    * @param mixed $option 组合条件的二维数组,例:$option['field1'] = array(1,'=>','or')
    * @return $this
    */
   public function where($option) {
       if ($this->_clear>0) $this->_clear();
       $this->_where = ' where ';
       $logic = 'and';
       if (is_string($option)) {
           $this->_where .= $option;
       }
       elseif (is_array($option)) {
           foreach($option as $k=>$v) {
               if (is_array($v)) {
                   $relative = isset($v[1]) ? $v[1] : '=';
                   $logic    = isset($v[2]) ? $v[2] : 'and';
                   $condition = ' ('.$this->_addChar($k).' '.$relative.' '.$v[0].') ';
               }
               else {
                   $logic = 'and';
                   $condition = ' ('.$this->_addChar($k).'='.$v.') ';
               }
               $this->_where .= isset($mark) ? $logic.$condition : $condition;
               $mark = 1;
           }
       }
       return $this;
   }
   /**
    * 设置排序
    * @param mixed $option 排序条件数组 例:array('sort'=>'desc')
    * @return $this
    */
   public function order($option) {
       if ($this->_clear>0) $this->_clear();
       $this->_order = ' order by ';
       if (is_string($option)) {
           $this->_order .= $option;
       }
       elseif (is_array($option)) {
           foreach($option as $k=>$v){
               $order = $this->_addChar($k).' '.$v;
               $this->_order .= isset($mark) ? ','.$order : $order;
               $mark = 1;
           }
       }
       return $this;
   }
   /**
    * 设置查询行数及页数
    * @param int $page pageSize不为空时为页数,否则为行数
    * @param int $pageSize 为空则函数设定取出行数,不为空则设定取出行数及页数
    * @return $this
    */
   public function limit($page,$pageSize=null) {
       if ($this->_clear>0) $this->_clear();
       if ($pageSize===null) {
           $this->_limit = "limit ".$page;
       }
       else {
           $pageval = intval( ($page - 1) * $pageSize);
           $this->_limit = "limit ".$pageval.",".$pageSize;
       }
       return $this;
   }
   /**
    * 设置查询字段
    * @param mixed $field 字段数组
    * @return $this
    */
   public function field($field){
       if ($this->_clear>0) $this->_clear();
       if (is_string($field)) {
           $field = explode(',', $field);
       }
       $nField = array_map(array($this,'_addChar'), $field);
       $this->_field = implode(',', $nField);
       return $this;
   }
   /**
    * 清理标记函数
    */
   protected function _clear() {
       $this->_where = '';
       $this->_order = '';
       $this->_limit = '';
       $this->_field = '*';
       $this->_clear = 0;
   }
   /**
    * 手动清理标记
    * @return $this
    */
   public function clearKey() {
       $this->_clear();
       return $this;
   }
   /**
   * 启动事务 
   * @return void 
   */ 
   public function startTrans() { 
       //数据rollback 支持 
       if ($this->_trans==0) self::$_dbh->beginTransaction();
       $this->_trans++; 
       return; 
   }
   
   /** 
   * 用于非自动提交状态下面的查询提交 
   * @return boolen 
   */
   public function commit() {
       $result = true;
       if ($this->_trans>0) { 
           $result = self::$_dbh->commit(); 
           $this->_trans = 0;
       } 
       return $result;
   }
   /** 
   * 事务回滚 
   * @return boolen 
   */ 
   public function rollback() {
       $result = true;
       if ($this->_trans>0) {
           $result = self::$_dbh->rollback();
           $this->_trans = 0;
       }
       return $result;
   }
   /**
   * 关闭连接
   * PHP 在脚本结束时会自动关闭连接。
   */
   public function close() {
       if (!is_null(self::$_dbh)) self::$_dbh = null;
   }
}

2. 例子

点卡销卡源码
点卡销卡源码

点卡销卡源码是一个以php+MySQL进行开发的点卡回收平台源码。软件必须使用宝塔面板进行搭建,否则有可能会出现无法安装的问题。

下载
101,
'aa'=>123456,
'bbc'=>'aaaaaaaaaaaaaa',
);
$mysql->insert('t_table',$data);
//查询
$res = $mysql->field(array('sid','aa','bbc'))
->order(array('sid'=>'desc','aa'=>'asc'))
->where(array('sid'=>"101",'aa'=>array('123455','>','or')))
->limit(1,2)
->select('t_table');
$res = $mysql->field('sid,aa,bbc')
->order('sid desc,aa asc')
->where('sid=101 or aa>123455')
->limit(1,2)
->select('t_table');
//获取最后执行的sql语句
$sql = $mysql->getLastSql();
//直接执行sql语句
$sql = "show tables";
$res = $mysql->doSql($sql);
//事务
$mysql->startTrans();
$mysql->where(array('sid'=>102))->update('t_table',array('aa'=>666666));
$mysql->where(array('sid'=>103))->update('t_table',array('bbc'=>'呵呵8888呵呵'));
$mysql->where(array('sid'=>104))->delete('t_table');
$mysql->commit();
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

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

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.02.06

java多线程方法汇总
java多线程方法汇总

本专题整合了java多线程面试题、实现函数、执行并发相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.02.06

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

90

2026.02.06

快手网页版入口与电脑端使用指南 快手官方短视频观看入口
快手网页版入口与电脑端使用指南 快手官方短视频观看入口

本专题汇总了快手网页版的最新入口地址和电脑版使用方法,详细提供快手官网直接访问链接、网页端操作教程,以及如何无需下载安装直接观看短视频的方式,帮助用户轻松浏览和观看快手短视频内容。

15

2026.02.06

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

10

2026.02.06

Python 微服务架构与 FastAPI 框架
Python 微服务架构与 FastAPI 框架

本专题系统讲解 Python 微服务架构设计与 FastAPI 框架应用,涵盖 FastAPI 的快速开发、路由与依赖注入、数据模型验证、API 文档自动生成、OAuth2 与 JWT 身份验证、异步支持、部署与扩展等。通过实际案例,帮助学习者掌握 使用 FastAPI 构建高效、可扩展的微服务应用,提高服务响应速度与系统可维护性。

6

2026.02.06

JavaScript 异步编程与事件驱动架构
JavaScript 异步编程与事件驱动架构

本专题深入讲解 JavaScript 异步编程与事件驱动架构,涵盖 Promise、async/await、事件循环机制、回调函数、任务队列与微任务队列、以及如何设计高效的异步应用架构。通过多个实际示例,帮助开发者掌握 如何处理复杂异步操作,并利用事件驱动设计模式构建高效、响应式应用。

7

2026.02.06

java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

25

2026.02.05

java中fail含义
java中fail含义

本专题整合了java中fail的含义、作用相关内容,阅读专题下面的文章了解更多详细内容。

28

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
php初学者入门课程
php初学者入门课程

共10课时 | 0.6万人学习

PHP基础入门课程
PHP基础入门课程

共33课时 | 2.1万人学习

第二十四期_PHP8编程
第二十四期_PHP8编程

共86课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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