博主信息
博文 25
粉丝 0
评论 0
访问量 20148
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
0802接口作业
杨发国的博客
原创
727人浏览过

实例

<?php
namespace _0802;
interface DbCrud
{
    public function create($data);
    public function read();
    public function update($data,$where);
    public function delete($where);
}
class Db implements DbCrud
{
    protected $pdo=null;
    protected $user;

    public function __construct($pdo,$username,$password,$user)
    {
       $this->pdo = new \PDO($pdo,$username,$password);
       $this->user = $user;
    }

    public function create($data)
{
    $fields = '(name,age)';
    $values = '(:name,:age)';
    $sql = 'INSERT INTO '.$this->user . $fields . ' VALUES ' . $values;
    $smpt=$this->pdo->prepare($sql);
    $smpt->execute($data);

    return
       [
       'count'=>$smpt->rowCount(),
       'id'=>$this->pdo->lastInsertId()
   ];
}
    public function read($fields = '*' , $where='', $limit = '0, 5')
{
    $where = empty($where) ? '' : ' WHERE ' . $where;
    $limit = ' LIMIT ' . $limit;
    $sql = 'SELECT '. $fields  . ' FROM ' . $this->user. $where . $limit;

    $stmt = $this->pdo->prepare($sql);
    $stmt->execute();
    return $stmt->fetchAll(\PDO::FETCH_ASSOC);
}
    public function update($data,$where)
{
    $keyArr = array_keys($data);
    $set = '';

    foreach ($keyArr as $value) {
        $set .= $value . '= :' . $value. ',';
    }
    $set =rtrim($set, ', ');

    $sql = 'UPDATE '. $this->user.' SET '.$set.' WHERE '.$where;
    $stmt = $this->pdo->prepare($sql);
    $stmt->execute($data);
    return $stmt->rowCount();


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

    return $stmt->rowCount();
}

}

$dsn = 'mysql:host=127.0.0.1;dbname=php';
$username='root';
$password='root';
$user='user';

$Db= new Db($dsn, $username,$password,$user);
//$data = [
//    'name'=> '杨发国',
//    'age'=> 30,
// ];
//$res=$Db->create($data);
//echo '成功新增了'.$res['count'].'条记录'.'用户ID为'.$res['id'];
echo '<hr>';
foreach ($Db->read('id,name,age', 'age >=30') as $item) {
    print_r($item); echo '<br>';
}
echo '<hr>';
$data = [
    'name' => '作业增删改查',
    'age' => 50
];

$where = 'id = 1';
echo '成功的更新了: ' . $Db->update($data, $where) . ' 条记录';
echo '<hr>';

$where = 'id = 30';
echo '成功的删除了: ' . $Db->delete($where) . ' 条记录';

运行实例 »

点击 "运行实例" 按钮查看在线实例

2.png

 

 

5.png3.png

批改状态:合格

老师批语:通过这个案例你学到了什么呢? 复制代码谁都会, 最好谈点学后感...
本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系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+教程免费学