博主信息
博文 28
粉丝 1
评论 0
访问量 21564
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
2019.6.18作业
关超的博客
原创
806人浏览过

写一个接口, 完成基本的数据表操作:CURD

interface iCurd
{
    public function add($data);

    // 查询
    public function select();

    // 更新
    public function update($data, $where);

    // 删除
    public function del($where);
}

class DB implements iCurd
{
    protected $pdo = null;
    protected $table;
    public function __construct($dsn, $user, $password, $table='user_info')
    {
        $this->pdo = new PDO($dsn, $user, $password);
        $this->table = $table;
    }

    public function select($fields='*', $where='', $limit='0, 10')
    {
        $where = empty($where) ? '' : ' WHERE ' . $where;
        $limit = ' LIMIT ' . $limit;
        
        $sql = 'SELECT '.$fields.' FROM '.$this->table.$where.$limit;
        $stmt = $this->pdo->prepare($sql);
        $stmt->execute();

        // 返回查询结果集
        return $stmt->fetchAll(PDO::FETCH_ASSOC);
    }

    public function add($data)
    {
        $fields = ' (name,age,sex,position,mobile,hiredate)';
        $values = '(:name,:age,:sex,:position,:mobile,:hiredate)';
        $sql = 'INSERT INTO '.$this->table.$fields.' VALUES '.$values;
        $stmt = $this->pdo->prepare($sql);
        $stmt->execute($data);
        return [
            'count'=>$stmt->rowCount(),
            'id'=>$this->pdo->lastInsertId()
        ];
    }

    public function update($data, $where)
    {
        $keyArr = array_keys($data);
        $set = '';
        foreach ($keyArr as $value) {
            $set .= $value . ' = :' .$value. ', ';
        }
     
        $set = rtrim($set,', ');
        $sql = 'UPDATE '.$this->table.' SET '.$set .' WHERE ' .$where;
        $stmt = $this->pdo->prepare($sql);
        $stmt->execute($data);

        // 返回被更新数量
        return $stmt->rowCount();
    }

    public function delete($where)
    {
        $sql = 'DELETE FROM '.$this->table.' WHERE '.$where;
        $stmt = $this->pdo->prepare($sql);
        $stmt->execute();
        return $stmt->rowCount();
    }
}


本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学