php对mysql pdo操作的封装(单例模式)

本文介绍了如何在PHP中使用PDO扩展来操作MySQL数据库,并结合单例模式进行封装,确保数据库连接的高效管理。首先,确保安装了pdo_mysql扩展,然后详细讲解了封装过程和单例模式的应用。
摘要由CSDN通过智能技术生成

需要先安装pdo_mysql扩展

<?php

/**
 * pdo处理mysql数据
 * Class Mysql
 */
class MysqlBuilder
{
    const PARAM_PREFIX = ':qp';

    private static $instance;

    private $pdo;

    private $dsn;

    private function __construct($dbConfig)
    {
        try{
            $host = $dbConfig['host'];
            $port = $dbConfig['port'];
            $user = $dbConfig['user'];
            $pass = $dbConfig['pass'];
            $database = $dbConfig['database'];
            $charset = $dbConfig['charset'];

            $this->dsn = "mysql:host=$host;port=$port;dbname=$database;charset=$charset";
            $this->pdo = new \PDO($this->dsn, $user, $pass);
        }catch (\PDOException $e){
            die($e->getMessage());
        }
    }

    private function __Clone()
    {

    }

    /**
     * @param $dbConfig
     * @return MysqlBuilder
     */
    public static function getInstance($dbConfig)
    {
        if(!(self::$instance instanceof self))
        {
            self::$instance = new self($dbConfig);
        }

        return self::$instance;
    }

    /**
     * @param $sql
     * @param array $params
     * @return int
     */
    public function execute($sql, $params = [])
    {
        try{
            $statement = $this->prepare($sql);
            $statement->execute($params);
            $affectRows = $statement->rowCount();
        }catch (\Exception $e){
            die($e->getMessage());
        }

        return $affectRows;
    }

    /**
     * 准备要执行的sql语句
     * @param $sql
     * @return \PDOStatement
     */
    protected function prepare($sql)
    {
  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值