pdo 操作类
来源:SegmentFault
时间:2023-01-24 09:29:50 400浏览 收藏
本篇文章向大家介绍《pdo 操作类》,主要包括MySQL,具有一定的参考价值,需要的朋友可以参考一下。
1.代码示例
<?php namespace extend\drive;
use \PDO;
use \Exception;
use PDOException;
/**
* Created by PhpStorm.
* User: Administrator
* Date: 16-10-5
* Time: 上午10:09
*/
class Db{
protected static $_instance = null;
protected $dbName = '';
protected $dsn;
protected $dbn;
/**
* 构造方法
* @author mmy
*/
public function __construct($dbHost,$dbUser,$dbPasswd,$dbName,$charSet)
{
try
{
$this->dsn = 'mysql:host='.$dbHost.';dbname='.$dbName;
$this->dbn = new PDO($this->dsn, $dbUser, $dbPasswd);
$this->dbn->exec('SET character_set_connection='.$charSet.', character_set_results='.$charSet.'character_set_client=binary');
}catch(PDOException $e){
$this->outputError($e->getMessage());
}
}
/**
* 输出错误信息
* @author mmy
*/
private function outputError($errorMessage)
{
throw new Exception('MySql Error:'.$errorMessage);
}
/**
* 单例模式
* @author mmy
* @ return obj
*/
public static function getInstance($dbHost,$dbUser,$dbPasswd,$dbName,$charSet)
{
if(self::$_instance===null)
{
self::$_instance = new self($dbHost,$dbUser,$dbPasswd,$dbName,$charSet);
}
return self::$_instance;
}
/**
* 防止克隆
* @author mmy
*/
private function __clone(){}
/**
* 调试方法
* @author mmy
*/
private function debug($debugInfo)
{
var_dump($debugInfo);
exit();
}
/**
* 执行sql语句
* @author mmy
*
*/
public function execSql($sql, $debug=false)
{
if($debug===true)
{
$this->debug($sql);
}
$result = $this->dbn->exec($sql);
$this->getPDOError();
return $result;
}
/**
* 捕获pdo错误消息
* @author mmy
*/
private function getPDOError()
{
if($this->dbn->errorCode() !='00000')
{
$arrayError = $this->dbn->errorInfo();
$this->outputError($arrayError[2]);
}
}
}
循环引用目录当中的文件
// 加载所有Applications/*/start.php,以便启动所有服务
foreach(glob(__DIR__.'/Applications/*/start*.php') as $start_file)
{
require_once $start_file;
}今天带大家了解了MySQL的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
最新阅读
更多>
-
117 收藏
-
411 收藏
-
420 收藏
-
264 收藏
-
266 收藏
-
392 收藏
-
333 收藏
-
234 收藏
-
448 收藏
-
416 收藏
-
225 收藏
-
145 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习