PDO模块类的封装(二)

​ // 实例化PDO对象
<?php

/*
 	PDO 接口封装
 */

class db

{

    public $pdo;

    public $err = "ok";             //建立异常属性

    public function __construct()           // 构造函数->实例化PDO对象

    {

        try {

            $conn = 'mysql:host=localhost; port=3306; dbname=lx; ';

            $usr = 'root';

            $pwd = 'root';

            $this->pdo = new PDO($conn, $usr, $pwd);                   // 创建PDO 对象

            $this->pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);           			//设置属性 抛出异常

            $this->pdo->query('set names utf8');           // 设置编码

        } catch (PDOException $errobj) {

            $this->err = $errobj->getMessage() . 'IN' . $errobj->getFile() . 'AT' . $errobj->getLine();

        }

    }
​ // 取得结果集对象
 /*

     \* 取得结果集对象

     \* @param sql string sql语句

     \* @param row array  数据(数组)

     \* @return object 结果集对象

     */

    function get_stmt($sql, array $row = [])

    {

        try {

            if ($this->pdo == null) return false;

            // 预执行语句

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

            // 参数绑定

            foreach ($row as $key => $val) {

             // $item->bindvalue(":$key", $val);           //绑定数组的 标记为KEY,值为vaL;

                $item->bindvalue($key + 1, $val);

            }

            // 执行

            $item->execute();

            return $item;

        } catch (PDOException $errObj) {

            $this->err = $errObj->getMessage() . ' IN ' . $errObj->getFile() . '  AT ' . $errObj->getLine();

            return false;

        }

    }
// 查询操作
 /*

     \* 执行查询操作的结果

     \* @param sql string sql语句

     \* @param row array  数据(数组)

     \* @param dType int  数据类型:2->二维;1->一维; 0->单值

     \* @param rType string  结果类型:array->数组; object->对象 字串 或 数值 | false

    */

    public function get_open($sql, array $row = [], $dType = 1, $rType = 'array')    

    {

        $item = $this->get_stmt($sql, $row);

        $item->execute();

        switch ($dType) {

            case 0:

                return $item->rowcount();

            case 1:

                return $item->fetch($rType == 'array' ? PDO::FETCH_ASSOC : PDO::FETCH_OBJ);

            case 2:

                return $item->fetchall($rType == 'array' ? PDO::FETCH_ASSOC : PDO::FETCH_OBJ);

        }

        return $item;

    }
// 增、删、改操作
 /**

     \* 执行增删改操作,返回受影响的行数

     \* @param sql string sql语句

     \* @param row array  数据(数组)

     \* return int 或 false

     */

    function get_count($sql, array $row = [])        // 返回受影响行数

    {

        $item = $this->get_stmt($sql, $row);

        return $item->rowcount();

    }

    // 取回错误信息

    public function get_err()

    {

        return $this->err;

    }

}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值