PHP用PDO如何封装简单易用的DB类详解

前言

PDO扩展为PHP访问数据库定义了一个轻量级的、一致性的接口,它提供了一个数据访问抽象层,这样,无论使用什么数据库,都可以通过一致的函数执行查询获取数据。PDO随PHP5.1发行,在PHP5.0的PECL扩展中也可以使用。

我个人理解:PDO是一个抽象类,为我们提供访问数据的接口方法,下面这篇将给大家介绍关于PHP如何利用PDO封装简单易用的DB类,下面话不多说,来一起看看详细的介绍:

使用

创建测试库和表

rush:sql;"> create database db_test; CREATE TABLE `user` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT,`name` char(11) NOT NULL,`created_at` int(10) unsigned NOT NULL,PRIMARY KEY (`uid`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; INSERT INTO `user` VALUES ('1','wang','1501109027'); INSERT INTO `user` VALUES ('2','meng','1501109026'); INSERT INTO `user` VALUES ('3','liu','1501009027'); INSERT INTO `user` VALUES ('4','yuan','1500109027');

代码测试

__setup([ 'dsn'=>'MysqL:dbname=db_test;host=localhost','username'=>'root','password'=>'******','charset'=>'utf8' ]);

$user = $db->fetch('SELECT * FROM user where id = :id',['id' => 1]);
echo $user['name'];
echo "\n";

$insertId = $db->insert('user',['name' => 'salamander','created_at' => time()]);
echo "insert user {$insertId}\n";
$users = $db->fetchAll('SELECT * FROM user');
foreach ($users as $item) {
echo "user {$item['id']} is {$item['name']} \n";
}

运行结果

DB工具类

rush:PHP;"> class DB
{
private $dsn;
private $sth;
private $dbh;
private $user;
private $charset;
private $password;

public $lastSQL = '';

public function __setup($config = array())
{
$this->dsn = $config['dsn'];
$this->user = $config['username'];
$this->password = $config['password'];
$this->charset = $config['charset'];
$this->connect();
}

private function connect()
{
if(!$this->dbh){
$options = array(
\PDO::MysqL_ATTR_INIT_COMMAND => 'SET NAMES ' . $this->charset,);
$this->dbh = new \PDO($this->dsn,$this->user,$this->password,$options);
}
}

public function beginTransaction()
{
return $this->dbh->beginTransaction();
}

public function inTransaction()
{
return $this->dbh->inTransaction();
}

public function rollBack()
{
return $this->dbh->rollBack();
}

public function commit()
{
return $this->dbh->commit();
}

function watchException($execute_state)
{
if(!$execute_state){
throw new MysqLException("sql: {$this->lastsql}\n".$this->sth->errorInfo()[2],intval($this->sth->errorCode()));
}
}

public function fetchAll($sql,$parameters=[])
{
$result = [];
$this->lastsql = $sql;
$this->sth = $this->dbh->prepare($sql);
$this->watchException($this->sth->execute($parameters));
while($result[] = $this->sth->fetch(\PDO::FETCH_ASSOC)){ }
array_pop($result);
return $result;
}

public function fetchColumnAll($sql,$parameters=[],$position=0)
{
$result = [];
$this->lastsql = $sql;
$this->sth = $this->dbh->prepare($sql);
$this->watchException($this->sth->execute($parameters));
while($result[] = $this->sth->fetch(\PDO::FETCH_COLUMN,$position)){ }
array_pop($result);
return $result;
}

public function exists($sql,$parameters=[])
{
$this->lastsql = $sql;
$data = $this->fetch($sql,$parameters);
return !empty($data);
}

public function query($sql,$parameters=[])
{
$this->lastsql = $sql;
$this->sth = $this->dbh->prepare($sql);
$this->watchException($this->sth->execute($parameters));
return $this->sth->rowCount();
}

public function fetch($sql,$type=\PDO::FETCH_ASSOC)
{
$this->lastsql = $sql;
$this->sth = $this->dbh->prepare($sql);
$this->watchException($this->sth->execute($parameters));
return $this->sth->fetch($type);
}

public function fetchColumn($sql,$position=0)
{
$this->lastsql = $sql;
$this->sth = $this->dbh->prepare($sql);
$this->watchException($this->sth->execute($parameters));
return $this->sth->fetch(\PDO::FETCH_COLUMN,$position);
}

public function update($table,$condition=[])
{
$table = $this->format_table_name($table);
$sql = "UPDATE $table SET ";
$fields = [];
$pdo_parameters = [];
foreach ( $parameters as $field=>$value){
$fields[] = ''.$field.'=:field_'.$field;
$pdo_parameters['field_'.$field] = $value;
}
$sql .= implode(',',$fields);
$fields = [];
$where = '';
if(is_string($condition)) {
$where = $condition;
} else if(is_array($condition)) {
foreach($condition as $field=>$value){
$parameters[$field] = $value;
$fields[] = ''.$field.'=:condition_'.$field;
$pdo_parameters['condition_'.$field] = $value;
}
$where = implode(' AND ',$fields);
}
if(!empty($where)) {
$sql .= ' WHERE '.$where;
}
return $this->query($sql,$pdo_parameters);
}

public function insert($table,$parameters=[])
{
$table = $this->format_table_name($table);
$sql = "INSERT INTO $table";
$fields = [];
$placeholder = [];
foreach ( $parameters as $field=>$value){
$placeholder[] = ':'.$field;
$fields[] = ''.$field.'';
}
$sql .= '('.implode(",",$fields).') VALUES ('.implode(",$placeholder).')';

$this->lastsql = $sql;
$this->sth = $this->dbh->prepare($sql);
$this->watchException($this->sth->execute($parameters));
$id = $this->dbh->lastInsertId();
if(empty($id)) {
return $this->sth->rowCount();
} else {
return $id;
}
}

public function errorInfo()
{
return $this->sth->errorInfo();
}

protected function format_table_name($table)
{
$parts = explode(".",$table,2);

if(count($parts) > 1) {
$table = $parts[0].".{$parts[1]}";
} else {
$table = "$table";
}
return $table;
}

function errorCode()
{
return $this->sth->errorCode();
}
}

class MysqLException extends \Exception { }

框架中使用建议

在框架中使用DB类,用单例模式或者用依赖容器来管理较好。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


服务器优化必备:深入了解PHP8底层开发原理
Golang的网络编程:如何快速构建高性能的网络应用?
Golang和其他编程语言的对比:为什么它的开发效率更高?
PHP8底层开发原理揭秘:如何利用新特性创建出色的Web应用
将字符重新排列以形成回文(如果可能)在C++中
掌握PHP8底层开发原理和新特性:创建高效可扩展的应用程序
服务器性能优化必学:掌握PHP8底层开发原理
PHP8新特性和底层开发原理详解:优化应用性能的终极指南
将 C/C++ 代码转换为汇编语言
深入研究PHP8底层开发原理:创建高效可扩展的应用程序
C++程序查找法向量和迹
PHP8底层开发原理实战指南:提升服务器效能
重排数组,使得当 i 为偶数时,arr[i] >= arr[j],当 i 为奇数时,arr[i] <= arr[j],其中 j < i,使用 C++ 语言实现
Golang的垃圾回收:为什么它可以减少开发人员的负担?
C++程序:将一个数组的所有元素复制到另一个数组中
Golang:构建智能系统的基石
为什么AI开发者应该关注Golang?
在C和C++中,逗号(comma)的用法是用来分隔表达式或语句
PHP8底层开发原理解析及新特性应用实例
利用PHP8底层开发原理解析新特性:如何构建出色的Web应用