<?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. Problem H. The Fence 通过取余判重,求得某个区间的某些个数为某个数的倍数。

    /** 题目:Problem H. The Fence 链接:https://vjudge.net/problem/Gym-101090H 题意:给定一个字符串,只有0或者1: 问:假如两个不同的1之 ...

  2. C#通过修改注册表改变IE默认选项

    修改注册表,这个代码好实现,关键是怎么找到对应的注册表值,也就是说画一条线很容易,难的是找到要在哪里画,然后我百度了一圈,出来的都是画线的,没有指出或者指出的不全的注册表对应值,只能FQ谷歌了,也就有 ...

  3. android自定义View_3——Optimizing the View

    前言:现在你已经有了一个自定义的view了,并且支持手势和过度动画等属性,现在你要确认这个view 有够快的速度,为了使其在UI上不会显得迟钝或是卡停,你要保证view动画,能每秒最好有60帧. 一: ...

  4. windows文件打包命令

    copy /Y partition.bin /b + qcsblhd_cfgdata.bin /b + qcsbl.bin /b + oemsbl.bin /b + fat.amss.bin /b + ...

  5. ABAP小白的成长日记--------helloblog

    在外企公司培训了3个月,系统的学习了ABAP,希望开通Blog以后和大家一起深入学习交流.印度人的办事效率是出奇的低,赶超国企公务员.虽然内容cover到了几乎所有R/4的内容,但是还有很多知识没有真 ...

  6. redis 集群出现的错误

    1 解决方法: 不用 Jedis jed =new jedis("192.168.56.101"); jed.set(key,value); 用 Set<HostAndPor ...

  7. TLE之前,没有一个节点叫失败!!!

    我想我十八年来记忆最深刻的夜晚,大概便是在吉林大学燥热的宿舍里,穿着橘黄色的短袖,努力咽下大口大口的雪碧.那天晚上我仰躺在吉大热得几乎不能入眠的床板上,一动不动,看夏夜里打不尽的蚊子在惨白的天花板下飞 ...

  8. 【BZOJ2034】[2009国家集训队]最大收益 贪心优化最优匹配

    [BZOJ2034][2009国家集训队]最大收益 Description 给出N件单位时间任务,对于第i件任务,如果要完成该任务,需要占用[Si, Ti]间的某个时刻,且完成后会有Vi的收益.求最大 ...

  9. E - Rails (栈)

    E - Rails Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Description The ...

  10. text files and binary files

    https://en.wikipedia.org/wiki/Text_file https://zh.wikipedia.org/wiki/文本文件