>  기사  >  백엔드 개발  >  PHP 전자상거래 장바구니(2: 데이터베이스 작업 클래스 캡슐화)

PHP 전자상거래 장바구니(2: 데이터베이스 작업 클래스 캡슐화)

WBOY
WBOY원래의
2016-07-28 08:28:021000검색

                                              데이터베이스 다음에는 데이터베이스 운영 수업을 캡슐화해야 합니다(자비 교사 참조). Mypdo의 경우 이 글 뒤에 PDO 요약이 첨부됩니다(학습 요약 모듈에서).

 

구성 파일(현재 클래스 파일과 동일한 디렉터리 파일에 있음)

<?php
/**
 * 自己封装的Pdo操作类
 * User: hangfu
 * Date: 2016-6-24
 * Time: 16:36
 * version: 1.0.0.1
 */

class MyPdo{
    /**
     * @var Pdo  私有的PDO对象
     */
    private $pdo;
    /**
     * 构造方法,用于初始化PDO对象
     */
    public function __construct(){
        if(file_exists(_DIR_.&#39;db.ini&#39;)){        
                  $ini = parse_ini_file(&#39;db.ini&#39;);
            $dsn = $ini[&#39;db&#39;].":host=".$ini[&#39;host&#39;].";dbname=".$ini[&#39;dbname&#39;].";port=".$ini[&#39;host&#39;]
                .";charset=".$ini[&#39;charset&#39;];
        }else{
            die(&#39;配置文件不存在....&#39;);
        }
        $this->pdo = new PDO($dsn, $ini['username'], $ini['userpwd']);
    }

    /**
     * 析构方法,用于销毁时同时销毁PDO对象
     */
    public function __destruct(){
        if($this->pdo)
            $this->pdo = null;
    }

    /**
     * 接收SQL(DML)语句并执行返回受影响的行数
     * @param $sql 传入的sql语句字符串
     */
    public function pdoExec($sql){
        return $this->pdo->exec($sql);
    }

    /**
     * 接收SQL(DQL)语句,该语句不带参数,执行并返回查询结果,返回的值为二维数组;如果没有结果,返回null
     * @param $sql 传入的sql语句字符串
     */
    public function pdoQuery($sql){
        $data = $this->pdo->query($sql);
        if($data){
            return $data->fetchAll(PDO::FETCH_NUM);
        }else{
            return null;
        }
    }
    /**
     * 接收SQL(DQL)语句,该语句不带参数,执行并返回查询结果,返回的值为二维数组;如果没有结果,返回null
     * @param $sql 传入的sql语句字符串
     * @param $objname 传入的对象名称,字符串格式
     */
    public function pdoQueryByObj($sql, $objname){
        $data = $this->pdo->query($sql);
        if($data){
            $datalist = array();
            while($info=$data->fetchObject($objname)){
                array_push($datalist, $info);
            }
            return $datalist;
        }else{
            return null;
        }
    }
    /**
     * 接收SQL(DQL)语句,该语句带参数,执行并返回查询结果,返回的值为二维数组;如果没有结果,返回null
     * @param $sql 传入的sql语句字符串
     * @param $arr 传入的参数值,数组格式
     */
    public function pdoPrepare($sql, $arr){
        $data = $this->pdo->prepare($sql);
        $bl = $data->execute($arr);
        if($bl){
            return $data->fetchAll(PDO::FETCH_NUM);
        }else{
            return null;
        }
    }
    /**
     * 接收SQL(DQL)语句,该语句不带参数,执行并返回查询结果,返回的值为二维数组;如果没有结果,返回null
     * @param $sql 传入的sql语句字符串
     * @param $objname 传入的对象名称,字符串格式
     * @param $arr 传入的参数值,数组格式
     */
    public function pdoPrepareByObj($sql, $objname, $arr){
        $data = $this->pdo->prepare($sql);
        $bl = $data->execute($arr);
        if($bl){
            $datalist = array();
            while($info=$data->fetchObject($objname)){
                array_push($datalist, $info);
            }
            return $datalist;
        }else{
            return null;
        }
    }
}

 
###数据库类型
db=mysql
###数据库名称
dbname=phpwork
###服务器地址或名称
host=localhost
###数据库字符集
charset=utf8
###数据库端口号
port=3306
###操作的用户名
username=xuzhengyang
###操作的用户密码
userpwd=



 

이상으로 PHP 전자상거래 장바구니(Part 2: 데이터베이스 연산 캡슐화 클래스)를 다양한 측면에서 소개했습니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되길 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.