0

0

PHP数据库基于PDO操作类(mysql)

不言

不言

发布时间:2018-04-13 17:57:06

|

2435人浏览过

|

来源于php中文网

原创

本篇文章分享的内容是PHP数据库基于PDO操作类(mysql),现在分享给大家,有需要的朋友可以参考一下本篇文章的内容

PHP数据库基于PDO操作类(mysql)




这是网上找的关于Mysql的操作类,非常适合初学者使用

复制代码

_host = $conf['host'];            $this->_port = $conf['port'];            $this->_user = $conf['user'];            $this->_pass = $conf['password'];            $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)) { 
                        //将字符串中的单引号(')、双引号(")、反斜线(\)与 NUL(NULL 字符转义
                        $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);            //echo $sql;
            $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;
        }

}

相关推荐:

PHP数据库保存session会话

php数据库比较工具分享

SmartB2B行业电子商务
SmartB2B行业电子商务

SmartB2B 是一款基于PHP、MySQL、Smarty的B2B行业电子商务网站管理系统,系统提供了供求模型、企业模型、产品模型、人才招聘模型、资讯模型等模块,适用于想在行业里取得领先地位的企业快速假设B2B网站,可以运行于Linux与Windows等多重服务器环境,安装方便,使用灵活。 系统使用当前流行的PHP语言开发,以MySQL为数据库,采用B/S架构,MVC模式开发。融入了模型化、模板

下载

php数据库操作记录

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

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

下载

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

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

1987

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1304

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1212

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1400

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1229

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1439

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 778人学习

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

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