PHP PDO_MYSQL 链式操作 非链式操作类
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4: */
// +----------------------------------------------------------------------+
// | PHP version 5 |
// +----------------------------------------------------------------------+
// | Copyright (c) 1997-2004 The PHP Group |
// +----------------------------------------------------------------------+
// | This source file is subject to version 3.0 of the PHP license, |
// | that is bundled with this package in the file LICENSE, and is |
// | available through the world-wide-web at the following url: |
// | http://www.php.net/license/3_0.txt. |
// | If you did not receive a copy of the PHP license and are unable to |
// | obtain it through the world-wide-web, please send a note to |
// | license@php.net so we can mail you a copy immediately. |
// +----------------------------------------------------------------------+
// | Authors: Original Author <author@example.com> |
// | Your Name <you@example.com> |
// +----------------------------------------------------------------------+
//
// $Id:$ class pdomysql {
public $dbtype = 'mysql';
public $dbhost = '127.0.0.1';
public $dbport = '3306';
public $dbname = 'test';
public $dbuser = 'root';
public $dbpass = '';
public $charset = 'utf-8';
public $stmt = null;
public $DB = null;
public $connect = true; // 是否長连接
public $debug = true;
private $parms = array();
private $sql = array(
"db" => "",
"from" => "",
"where" => "",
"order" => "",
"limit" => ""
);
/**
* 构造函数
*/
public function __construct() { $this->connect();
$this->DB->setAttribute(PDO::MYSQL_ATTR_USE_BUFFERED_QUERY, true);
$this->DB->setAttribute(PDO::ATTR_EMULATE_PREPARES, true);
$this->execute('SET NAMES ' . $this->charset);
}
/**
* 析构函数
*/
public function __destruct() {
$this->close();
}
/**
* *******************基本方法开始********************
*/
/**
* 作用:连結数据库
*/
public function connect() {
try {
$this->DB = new PDO($this->dbtype . ':host=' . $this->dbhost . ';port=' . $this->dbport . ';dbname=' . $this->dbname, $this->dbuser, $this->dbpass, array(
PDO::ATTR_PERSISTENT => $this->connect
));
}
catch(PDOException $e) {
die("Connect Error Infomation:" . $e->getMessage());
}
}
/**
* 关闭数据连接
*/
public function close() {
$this->DB = null;
}
/**
* 對字串進行转義
*/
public function quote($str) {
return $this->DB->quote($str);
}
/**
* 作用:获取数据表里的欄位
* 返回:表字段结构
* 类型:数组
*/
public function getFields($table) {
$this->stmt = $this->DB->query("DESCRIBE $table");
$result = $this->stmt->fetchAll(PDO::FETCH_ASSOC);
$this->stmt = null;
return $result;
}
/**
* 作用:获得最后INSERT的主鍵ID
* 返回:最后INSERT的主鍵ID
* 类型:数字
*/
public function getLastId() {
return $this->DB->lastInsertId();
}
/**
* 作用:執行INSERT\UPDATE\DELETE
* 返回:执行語句影响行数
* 类型:数字
*/
public function execute($sql) {
$this->getPDOError($sql);
return $this->DB->exec($sql);
}
/**
* 获取要操作的数据
* 返回:合併后的SQL語句
* 类型:字串
*/
private function getCode($table, $args) {
$code = '';
if (is_array($args)) {
foreach ($args as $k => $v) {
if ($v == '') {
continue;
}
$code.= "`$k`='$v',";
}
}
$code = substr($code, 0, -1);
return $code;
}
public function optimizeTable($table) {
$sql = "OPTIMIZE TABLE $table";
$this->execute($sql);
}
/**
* 执行具体SQL操作
* 返回:运行結果
* 类型:数组
*/
private function _fetch($sql, $type) {
$result = array();
$this->stmt = $this->DB->query($sql);
$this->getPDOError($sql);
$this->stmt->setFetchMode(PDO::FETCH_ASSOC);
switch ($type) {
case '0':
$result = $this->stmt->fetch();
break; case '1':
$result = $this->stmt->fetchAll();
break; case '2':
$result = $this->stmt->rowCount();
break;
}
$this->stmt = null;
return $result;
}
/**
* *******************基本方法結束********************
*/
/**
* *******************Sql操作方法开始********************
*/
/**
* 作用:插入数据
* 返回:表內記录
* 类型:数组
* 參数:$db->insert('$table',array('title'=>'Zxsv'))
*/
public function add($table, $args) {
$sql = "INSERT INTO `$table` SET ";
$code = $this->getCode($table, $args);
$sql.= $code;
return $this->execute($sql);
}
/**
* 修改数据
* 返回:記录数
* 类型:数字
* 參数:$db->up($table,array('title'=>'Zxsv'),array('id'=>'1'),$where
* ='id=3');
*/
public function up($table, $args, $where) {
$code = $this->getCode($table, $args);
$sql = "UPDATE `$table` SET ";
$sql.= $code;
$sql.= " Where $where";
return $this->execute($sql);
}
/**
* 作用:刪除数据
* 返回:表內記录
* 类型:数组
* 參数:$db->del($table,$condition = null,$where ='id=3')
*/
public function del($table, $where) {
$sql = "DELETE FROM `$table` Where $where";
return $this->execute($sql);
}
/**
* 作用:获取單行数据
* 返回:表內第一条記录
* 类型:数组
* 參数:$db->fetOne($table,$condition = null,$field = '*',$where ='')
*/
public function fetOne($table, $field = '*', $where = false) {
$sql = "SELECT {$field} FROM `{$table}`";
$sql.= ($where) ? " WHERE $where" : '';
return $this->_fetch($sql, $type = '0');
}
/**
* 作用:获取所有数据
* 返回:表內記录
* 类型:二維数组
* 參数:$db->fetAll('$table',$condition = '',$field = '*',$orderby = '',$limit
* = '',$where='')
*/
public function fetAll($table, $field = '*', $orderby = false, $where = false) {
$sql = "SELECT {$field} FROM `{$table}`";
$sql.= ($where) ? " WHERE $where" : '';
$sql.= ($orderby) ? " ORDER BY $orderby" : '';
return $this->_fetch($sql, $type = '1');
}
/**
* 作用:获取單行数据
* 返回:表內第一条記录
* 类型:数组
* 參数:select * from table where id='1'
*/
public function getOne($sql) {
return $this->_fetch($sql, $type = '0');
}
/**
* 作用:获取所有数据
* 返回:表內記录
* 类型:二維数组
* 參数:select * from table
*/
public function getAll($sql) {
return $this->_fetch($sql, $type = '1');
}
/**
* 作用:获取首行首列数据
* 返回:首行首列欄位值
* 类型:值
* 參数:select `a` from table where id='1'
*/
public function scalar($sql, $fieldname) {
$row = $this->_fetch($sql, $type = '0');
return $row[$fieldname];
}
/**
* 获取記录总数
* 返回:記录数
* 类型:数字
* 參数:$db->fetRow('$table',$condition = '',$where ='');
*/
public function fetRowCount($table, $field = '*', $where = false) {
$sql = "SELECT COUNT({$field}) AS num FROM $table";
$sql.= ($where) ? " WHERE $where" : '';
return $this->_fetch($sql, $type = '0');
}
/**
* 获取記录总数
* 返回:記录数
* 类型:数字
* 參数:select count(*) from table
*/
public function getRowCount($sql) {
return $this->_fetch($sql, $type = '2');
}
//链式操作开始
public function from($tableName) {
$this->sql["from"] = "FROM " . $tableName;
return $this;
}
public function db($tableName) {
$this->sql["db"] = $tableName;
return $this;
}
public function where($_where = '1=1') {
$this->sql["where"] = "WHERE " . $_where;
return $this;
}
public function order($_order = 'id DESC') {
$this->sql["order"] = "ORDER BY " . $_order;
return $this;
}
public function limit($_limitstart="30",$_limitend = '0') {
if ($_limitend=="0"){
$this->sql["limit"] = "LIMIT 0," . $_limitstart;
}else{
$this->sql["limit"] = "LIMIT $_limitstart," . $_limitend;
} return $this;
}
/**
* 获取所有記录
* 返回:所有記录
* 类型:array
* 參数: $pdomysql->from('dbname')->limit(30)->where('1=1')->select();
*/
public function select($_select = '*') {
//return "SELECT " . $_select . " " . (implode(" ", $this->sql));
$sql="SELECT " . $_select . " " . (implode(" ", $this->sql));
return $this->_fetch($sql, $type = '1');
}
/**
* 获取一条記录
* 返回:一条記录
* 类型:array
* 參数: $pdomysql->from('dbname')->limit(30)->where('1=1')->find();
*/
public function find($_find = '*'){
$this->sql['limit']='limit 1';
$sql="SELECT " . $_find . " " . (implode(" ", $this->sql));
return $this->_fetch($sql, $type = '0');
}
/**
* 插入一条数据
* 返回:执行结果
* 类型:bool
* 參数: $pdomysql->db('dbname')->insert(array('col1'="sadsd"));
*/
public function insert($_insert=array()){
$table=$this->sql['db'];
$sql = "INSERT INTO `$table` SET ";
$code = $this->getCode($table, $args);
$sql.= $code;
return $this->execute($sql);
}
/**
* 删除
* 返回:删除结果
* 类型:bool
* 參数: $pdomysql->from('dbname')->where('1=1')->delete();
*/
public function delete(){
$sql="DELETE " . (implode(" ", $this->sql));
return $this->execute($sql);
}
public function update(){ }
//链式操作end
/**
* *******************Sql操作方法結束********************
*/
/**
* *******************错误处理开始********************
*/
/**
* 設置是否为调试模式
*/
public function setDebugMode($mode = true) {
return ($mode == true) ? $this->debug = true : $this->debug = false;
}
/**
* 捕获PDO错误信息
* 返回:出错信息
* 类型:字串
*/
private function getPDOError($sql) {
$this->debug ? $this->errorfile($sql) : '';
if ($this->DB->errorCode() != '00000') {
$info = ($this->stmt) ? $this->stmt->errorInfo() : $this->DB->errorInfo();
echo ($this->sqlError('mySQL Query Error', $info[2], $sql));
exit();
}
}
private function getSTMTError($sql) {
$this->debug ? $this->errorfile($sql) : '';
if ($this->stmt->errorCode() != '00000') {
$info = ($this->stmt) ? $this->stmt->errorInfo() : $this->DB->errorInfo();
echo ($this->sqlError('mySQL Query Error', $info[2], $sql));
exit();
}
}
/**
* 寫入错误日志
*/
private function errorfile($sql) {
echo $sql . '<br />';
$errorfile = __DIR__ . '/dberrorlog.php';
$sql = str_replace(array(
"\n",
"\r",
"\t",
" ",
" ",
" "
) , array(
" ",
" ",
" ",
" ",
" ",
" "
) , $sql);
if (!file_exists($errorfile)) {
$fp = file_put_contents($errorfile, "<?PHP exit('Access Denied'); ?>\n" . $sql);
} else {
$fp = file_put_contents($errorfile, "\n" . $sql, FILE_APPEND);
}
}
/**
* 作用:运行错误信息
* 返回:运行错误信息和SQL語句
* 类型:字符
*/
private function sqlError($message = '', $info = '', $sql = '') {
$html = '';
if ($message) {
$html.= $message;
}
if ($info) {
$html.= 'SQLID: ' . $info;
}
if ($sql) {
$html.= 'ErrorSQL: ' . $sql;
}
throw new Exception($html);
}
/**
* *******************错误处理結束********************
*/
}
PHP PDO_MYSQL 链式操作 非链式操作类的更多相关文章
- 阻塞式和非阻塞式IO
有很多人把阻塞认为是同步,把非阻塞认为是异步:个人认为这样是不准确的,当然从思想上可以这样类比,但方式是完全不同的,下面说说在JAVA里面阻塞IO和非阻塞IO的区别 在JDK1.4中引入了一个NIO的 ...
- 多态设计 zen of python poem 显式而非隐式 延迟赋值
总结 1.python支持延迟赋值,但是给调用者带来了困惑: 2.显式而非隐式,应当显式地指定要初始化的变量 class Card: def __init__(self, rank, suit): s ...
- Spring学习(1):侵入式与非侵入式,轻量级与重量级
一. 引言 在阅读spring相关资料,都会提到Spring是非侵入式编程模型,轻量级框架,那么就有必要了解下这些概念. 二. 侵入式与非侵入式 非侵入式:使用一个新的技术不会或者基本不改变原有代码结 ...
- 如何实现XA式、非XA式Spring分布式事务
Spring应用的几种事务处理机制 Java Transaction API和XA协议是Spring常用的分布式事务机制,不过你可以选择选择其他的实现方式.理想的实现取决于你的应用程序使用何种资源,你 ...
- Boostrap响应式与非响应式
非响应式布局 在使用非响应式布局时,在<head>标签中需要加入一下内容,其中最主要的是non-responsive.css文件 <head> <meta http-eq ...
- Java基础知识强化之多线程笔记07:同步、异步、阻塞式、非阻塞式 的联系与区别
1. 同步: 所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回.但是一旦调用返回,就必须先得到返回值了. 换句话话说,调用者主动等待这个"调用"的结果. 对于 ...
- Spring 侵入式和非侵入式
1.非侵入式的技术体现 允许在应用系统中自由选择和组装Spring框架的各个功能模块,并且不强制要求应用系统的类必须从Spring框架的系统API的某个类来继承或者实现某个接口. 2.如何实现非侵入式 ...
- 基于NIO写的阻塞式和非阻塞式的客户端服务端
由于功能太过简单,就不过多阐述了,直接上阻塞式代码: package com.lql.nio; import org.junit.Test; import java.io.IOException; i ...
- 登录式与非登录式&交互式与非交互式shell及其环境初始化过程
交互式shell和非交互式shell(interactive shell and non-interactive shell) 交互式模式就是在终端上执行,shell等待你的输入,并且立即执行你提交的 ...
随机推荐
- opencv python:图像直方图 histogram
直接用matplotlib画出直方图 def plot_demo(image): plt.hist(image.ravel(), 256, [0, 256]) # image.ravel()将图像展开 ...
- celery task - 2
# celery task 前言 讨论一个定时任务,一般而言,需要的功能如下: 封装成对象,独立执行: 对象有一些接口,便于了解它的状态: 定时调用: 行为控制,包括重试,成功/失败回调等: 下面分别 ...
- as(android studio)的初次使用
链接:https://blog.csdn.net/qq_28808627/article/details/50058805
- 16,div+css的布局较table布局有什么优点?
改版的时候更加方便,只要改css文件 页面加载速度更快,结构化清晰,页面显示简洁 表现与结构相分离 易于搜索引擎优化,排名更靠前
- 12306 selenium 模拟登录
# 下面是12306 实现的模拟登陆 # 解码 应用超级鹰,注册用户,左侧栏软件ID进去,开启一个新软件,拿到软件ID # 下面测试都在jupyter里面实现 # 超级鹰类 cell import r ...
- (二)tensorflow-gpu2.0之自动导数
import tensorflow as tf ''' 梯度:导数或偏导数 1.在什么点的导数:在点(a,b,c,w)=(1,2,3,4)点的导数 2.梯度环境 对谁求导: 对w求导 函数: y = ...
- IoT协议LwM2M MQTT与CoAP
IoT协议LwM2M MQTT与CoAP 一.MQTT 1.概述: MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)是IBM开发的一个即时通讯协议, ...
- Debian9安装Metasploit
参考博文:https://www.jianshu.com/p/ea0629b9e367 0x0 添加Kali源 deb http://http.kali.org/kali kali-rolling m ...
- vscode vue js 开发插件配置
安装 vetur { // 自动补全触发范围---双引号内的字符串也可以触发补全 "editor.quickSuggestions": { "other": t ...
- 杭电2504 又见GCD
又见GCD Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...