<?php
//添加了一个 _createSql 方法,负责创建所有sql
class Db{
static private $ins;
private $pdo;
private $table;
private $where;
private $field = '*';
private $joinWhere = 'where';
private $order;
private $limit; final private function __construct(){
//从配置文件读入数据库信息
$dsn = 'mysql:dbname=wxguide;host=127.0.0.1' ;
$user = 'root';
$password = ''; try {
$this->pdo = new PDO ( $dsn , $user , $password );
} catch ( PDOException $e ) {
die('Connection failed: ' . $e -> getMessage ());
}
} final private function __clone(){} static public function table($table){
if(!self::$ins instanceof self){
self::$ins = new self();
}
self::$ins->table = $table;
return self::$ins;
} public function query($sql){
return $this->pdo->query($sql);
} public function exec($sql){
return $this->pdo->exec($sql);
} public function insert($data){
$type = 'insert';
$sql = $this->_createSql($type,$data);
return $this->exec($sql);
} public function delete(){
$type = 'delete';
$sql = $this->_createSql($type);
return $this->exec($sql);
} public function update($data){
$type = 'update';
$sql = $this->_createSql($type,$data);
return $this->exec($sql);
} public function find(){
$type = 'select';
$sql = $this->_createSql($type);
return $this->query($sql)->fetch(PDO::FETCH_ASSOC);
} public function select(){
$type = 'select';
$sql = $this->_createSql($type);
return $this->query($sql)->fetchAll(PDO::FETCH_ASSOC); } //条件字符串的【条件的值】需要用 引号(值如果是数字可以不用,但是用也没影响,建议不用),如: $str = 'id = 1 and name = "王五" '
public function where($str){
$this->where = $str;
return $this;
} public function field($str){
$this->field = $str;
return $this;
} public function limit($numstr){
$this->limit = 'limit ' . $numstr;
return $this;
} public function order($str){
$this->order = 'order by ' . $str;
return $this;
} public function group(){ } public function having(){ } //给表取别名
public function alias($str){
$this->table .= ' ' . $str;
return $this;
} //可以多表联查,join('tb1 b,tb2 c','a,id=b.id and a.id = c.id')
//$join 可以取值 INNER,left或者right,默认值是 INNER
public function join($alias,$where = null,$join = 'INNER'){
$this->where .= $where;
if($join != 'INNER'){
$this->table .= ' '.$join . ' join ' . $alias;
$this->joinWhere = 'ON';
}else{
$this->table .= ',' . $alias;
}
return $this;
} //创建sql
private function _createSql($type,$data=null){
switch ($type) {
case 'insert':
$arr = $this->_cf($data);
$sql = 'insert into ' . $this->table . ' (' . $arr['kstr'] . ') VALUES (' . $arr['vstr'] . ')';
break; case 'delete':
$sql = 'delete from ' . $this->table . ' '.$this->joinWhere.' ' . $this->where;
break; case 'update':
$arr = $this->_cf($data);
$sql = 'update ' . $this->table . ' set '. $arr['ustr'] .' '.$this->joinWhere.' ' . $this->where;
break; case 'select':
$sql = 'select '. $this->field .' from ' . $this->table;
if($this->where){
$sql = $sql . ' '.$this->joinWhere.' ' . $this->where;
}
$sql .= ' '.$this->order;
$sql .= ' '. $this->limit;
break; default:
die('sql创建出现错误');
break;
}
$this->_clear();
return $sql;
} //属性数据还原
private function _clear(){
$this->table = '';
$this->where = '';
$this->field = '*';
$this->joinWhere = 'where';
$this->order = '';
$this->limit = '';
} //拆分 数组,组装数据
private function _cf($data){
$arr = [];
$str = '';
foreach($data as $k=>$v){
$arr['k'][] = $k;
$arr['v'][] = '"'.$v.'"';
$str .= $k . '="' . $v . '",';
}
$arr['kstr'] = implode(',',$arr['k']);
$arr['vstr'] = implode(',',$arr['v']);
$arr['ustr'] = rtrim($str, ",");
return $arr;
}
} header('Content-type:text/html;charset=gbk'); $a = Db::table('model')->where('1')->select();
print_r($a);

pdo封装2的更多相关文章

  1. PDO封装函数

    header("Content-type: text/html; charset=utf-8"); /** * 初始化 pdo 对象实例 * @param bool $newins ...

  2. pdo 封装增删改查类

    <?php/** * Class model * @package Core\lib */class model{    protected $pdo = null;      // 连接数据库 ...

  3. PDO封装增删改查

    <?phpclass db{ public $table=null; public $pdo; public $where=null; //where 条件 public $field=null ...

  4. 封装:PDO与MySQL之间的无缝切换

    以下的例子是将MySQL和PDO封装好,再无缝切换: 文件目录: config.php文件:   <?php return array( // 数据库配置 'DB' => array( ' ...

  5. PHP 封装POD 类

    使用POD的过程 //1.造DSN:驱动名:dbname=数据库名;host=服务器地址 $dsn = "mysql:dbname=mydb;host=localhost"; // ...

  6. 自学PHP的正确方法与经验

    我是2015年开始接触认识到PHP编程方面的知识,2012年我还是一名刚毕业的大学生开始踏入社会从事自己一份学校推荐的自动化职业,自动化工作枯燥无味,每天基本上3点一线,食堂-公司机器-宿舍,做了3年 ...

  7. php学习笔记——学习路线图记录

    PHP学习路线图 最全PHP自学指南 W3Cschool小编 2018-04-24 15:23:51 浏览数 (5381) 分享 收录专辑 对于广大零基础的PHP自学者,往往不知道如何系统的学习PHP ...

  8. 封装PDO函数

    funPDO.php <?php /** * @title: 封装PDO函数 * * @Features: * 1. 封装 SELECT ,INSERT,DELETE,UPDATE 操作 @do ...

  9. PDO 增删改查封装的类

    Selecting Data 你在mysql_*中是这样做的 <?php $result = mysql_query('SELECT * from table') or die(mysql_er ...

随机推荐

  1. Python os._exit() sys.exit() exit()区别

    Python退出程序的方式有两种:os._exit(), sys.exit() 1)os._exit() 直接退出 Python程序,其后的代码也不会继续执行. 2)sys.exit() 引发一个 S ...

  2. Razor 3、MVC 5

    Razor 3 需要vs 2012 update 4 才可以 需要装一个 Microsoft ASP.NET and Web Tools 2013.1 才会有 MVC 5

  3. Web应用程序使用Hibernate

    在本文中,我们将学习使用hibernate创建一个Web应用程序. 对于创建Web应用程序,我们使用JSP表示逻辑层,使用Bean类表示数据,以及使用DAO类操作数据库.在hibernate中创建简单 ...

  4. PowerDesigner 建模后如何导入到数据库

    from:https://jingyan.baidu.com/article/7f766daf465e9c4101e1d0d5.html 大家都知道PowerDesigner是一个数据库建模工具,但是 ...

  5. 第二篇:尽可能使用 const

    前言 const 关键字是常量修辞符,如果要告知编译器某个变量在程序中不会发生改变,则可将其声明为 const. 但,对 const 关键字的认识不能仅仅停留在这一层 - 它提供了很多更强大的功能. ...

  6. 关东升的《从零开始学Swift》即将出版

    大家好: 苹果2015WWDC大会发布了Swift2.0,它较之前的版本Swift1.x有很大的变化,所以我即将出版<从零开始学Swift> <从零开始学Swift>将在< ...

  7. java学习笔记——数据类型及类型转换

    数据类型分为: 1.引用类型(字符型); 2.基本数据类型(数值型); 以下为基本数据类型介绍(括号内的数字表示该类型所占据的字节数) a.整型 byte(8)   short(16)   int(3 ...

  8. C# 中正则表达式 Group 分组

    在一个正则表达式中,如果要提取出多个不同的部分(子表达式项),需要用到分组功能. 在 C# 正则表达式中,Regex 成员关系如下,其中 Group 是其分组处理类. Regex –> Matc ...

  9. Xcode生成ipa文件

    想到蒲公英应用做分发测试的同学们可以用的到哈 在测试的Device中切换为IOS Device,选择当前项目修改BuildSeting 在code signing Identity中选择证书,没有测试 ...

  10. iOS 关于自定义UICollectionViewLayout实现复杂布局

    UICollectionView的简单介绍 UICollectionView的结构 Cells Supplementary Views 追加视图 (类似Header或者Footer) Decorati ...