博主信息
世紀天城
博文
8
粉絲
1
評論
0
訪問量
1412
積分:0
P豆:16

新疆十一选五一定牛势图:自己搞了一天DB類 修改了一些東西 終于成功了

2019年12月07日 21:12:12閱讀數:385博客 / 世紀天城 / php心得

新疆十一选五预测号码今天 www.envkt.com 自己搞了一天DB類 修改了一些東西 終于成功了  大家來看看如何   討論討論



實例

<?php
class Db {

    //數據庫的連接對象
    protected $pdo = null;

    // 數據表名
//    protected $table;

    // 構造方法: 連接數據庫,并設置默認數據表名稱
    public function __construct($dsn, $user, $password){
        $this->pdo = new \PDO($dsn, $user, $password);
//        $this->table = $table;
    }

    // 讀取
    public function read($table,$where='', $fields='*'){
       $sql = 'SELECT ';
       if ($fields == '*'){
           $sql .= '* FROM ';
        }else{
           $sql .= $fields . ' FRPM ';
       }
       if ($table){
           $sql .= $table;
       }
       $sql .= $this->table;
       if (!$where == ''){
           $sql .= ' WHERE '.$where;
       }
        print_r($sql);
        echo '<br>';

        $stmt = $this->pdo->prepare($sql);

        if($stmt->execute()){
            if($stmt->rowCount()>0){
                $stmt->setFetchMode(PDO::FETCH_ASSOC);
                //返回一個二維數組
                return $stmt->fetchAll();
            }
        } else {
            return false;
        }

    }

    // 新增, 參數是數組: 新記錄的鍵值對
    public function create($table,$data){
        // 字段列表
        $fields = ' (name,alias)';
        // 值列表
        $values = '(:name,:alias)';
        // 創建SQL語句
        $sql = 'INSERT INTO '.$table.$this->table.$fields.' VALUES '.$values;
        print_r( $sql);
        // 預處理執行新增操作
        $stmt = $this->pdo->prepare($sql);
        $stmt->execute($data);

        // 返回新增數量, 新增記錄的ID組成的數組
        return [
            'count'=>$stmt->rowCount(),
            'id'=>$this->pdo->lastInsertId()
        ];
    }

    // 更新, 為了數據安全, 不允許無條件更新
    public function update($table,$data, $where){
        // 難點在于SET 參數的處理上,利用傳入的$data數組,進行拆裝

        // 獲取數組的鍵名組成的數組
        $keyArr = array_keys($data);
        $set = '';
        // 遍歷鍵名表示的字段列表,拼裝預處理需要的sql語句,注意占符符的表示
        foreach ($keyArr as $value) {
            $set .= $value . ' = :' .$value. ', ';
//            print_r($set);
        }
        // 去掉最后一個逗號, 注意每個逗號后有一個空格,去除時也要帶上這個空格
        $set = rtrim($set,', ');

        // 預處理執行更新操作
        $sql = 'UPDATE '.$table.' SET '.$set .' WHERE ' .$where;
        print_r($sql);
        $stmt = $this->pdo->prepare($sql);
        $stmt->execute($data);

        // 返回被更新的記錄數量
        return $stmt->rowCount();
    }

    // 刪除: 與更新一樣, 這也是危險的寫操作, 不允許無條件刪除
    public function delete($table,$where){
        // 預處理執行刪除操作
        $sql = 'DELETE FROM '.$table.' WHERE '.$where;

        $stmt = $this->pdo->prepare($sql);
        $stmt->execute();
        return $stmt->rowCount();
    }
}
$dsn = 'mysql:host=localhost;dbname=cms';
$user = 'root';
$password = 'root';
$db = new Db($dsn, $user, $password);
//$a = $db->read('category');
//print_r($a);

// 新增數據
$data = [
    'name'=>'kh',
    'alias'=>'科幻電影'
];
//$res = $db->create('category',$data);
//echo '成功新增'.$res['count'].'條記錄,最新記錄的主鍵ID是: '.$res['id'];

// 更新記錄
$data = [
    'alias'=>'搞怪電影',
    'name'=>'gg',
];
$where = 'cate_id = 6';
//echo '成功更新了: ' .$db->update('category',$data, $where). ' 條記錄';

// 刪除記錄
$where = 'cate_id = 9';
//echo '成功刪除了: ' .$db->delete('category',$where). ' 條記錄';

運行實例 ?

點擊 "運行實例" 按鈕查看在線實例


全部評論

文明上網理性發言,請遵守新聞評論服務協議

條評論
暫無評論暫無評論!