面向对象—工厂模式示例(数据库示例)

<?php
header("content-type:text/html;charset=utf8");
class DBFactory{

    public static function create($type){

        return  new $type;

    }
}
/**
 * 定义接口
 */
interface DB{
    public function connect();
    public function exec($sql);
    public function query($sql);
    public function add($arr);
    public function find($where);
    public function del($where);
    public function save($arr,$where);

}
/**
 * 具体封装方法
 */
class Mysql implements DB{
    public $dsn;
    public function __construct(){
        $this->dsn = "mysql:host=127.0.0.1;dbname=cms";
    }

    //链接数据库
    public function connect(){
        $pdo = new PDO($this->dsn, 'root', 'root');
        $pdo->exec("set names utf8");
        return $pdo;

    }
    //具体执行的方法
    public function exec($sql){

        return $this->connect()->exec($sql);
    }
    public function query($sql){

        return $this->connect()->query($sql);
    }

    //增
    public function add($arr)
    {

        $key = '';
        $value = '';
        foreach($arr as $k=>$v)
        {
            $key .= "$k,";
            $value .= "'$v',";
        }
        $key = substr($key,0,-1);
        $value = substr($value,0,-1);
        $sql = "insert into cmss ($key) values ($value)";
        $res = $this->exec($sql);
        return $res;
    }
    //删
    public function del($where)
    {

        $sql = "delete from cmss where $where";
        $res = $this->exec($sql);
        return $res;
    }
    //改
    public function save($arr,$where)
    {

        $str = '';
        foreach($arr as $k=>$v)
        {
            $str .= "$k='$v',";
        }
        $str = substr($str,0,-1);
        $sql = "update cmss set $str where $where";
        $res = $this->exec($sql);
        return $res;
    }
    //查
    public function find($where)
    {

        $sql = "select * from cmss where $where";
        $arr = $this->query($sql)->fetchAll(PDO::FETCH_ASSOC);
        return $arr;
    }



}
$mysql = DBFactory::create("Mysql");
$res = $mysql->find("1");
var_dump($res);











?>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值