php 设计模式之 工厂模式


Posted in PHP onDecember 19, 2008

本人常用mysql数据库,所以程序只写了mysql的数据库操作类。希望各位高手把另外的类写全,最好能发一份给我。
db_mysql.php继承db.php接口,具体实现数据库操作的各种方法 ,如果你确定你的数据库平台不会变的话不用工厂类,直接用这个就行了。

<?php 
/** 
* @author 黄建文 
* @version V1.0 
* @email hjwtp2005@qq.com 
* @data 2008-12-16 
* ================================================================== 
* @example 
* include 'db_mysql.php'; 
* $db=new db_mysql('localhost','root','admin','emtit'); 
* $sqlstr="SELECT * FROM member WHERE memberid=1"; 
* var_dump($db->get_one($sqlstr)); 
* =================================================================== 
*/ 
include 'db.php'; 
class db_mysql implements db { private $connid; 
public function db_mysql($dbhost,$username,$passowrd,$dbname='',$dbcharset='utf8'){ 
$this->connid=mysql_connect($dbhost,$username,$passowrd); 
if (!$this->connid){ 
$this->halt('Can not connect to MySQL server'); 
} 
if (emptyempty($dbcharset)){ 
$dbcharset='utf8'; 
} 
// 当mysql版本为4.1以上时,启用数据库字符集设置 
if($this->version() > '4.1' && $dbcharset) 
{ 
mysql_query("SET NAMES '".$dbcharset."'" , $this->connid); 
} 
// 当mysql版本为5.0以上时,设置sql mode 
if($this->version() > '5.0') 
{ 
mysql_query("SET sql_mode=''" , $this->connid); 
} 
if (!emptyempty($dbname)){ 
$this->select_db($dbname); 
} 
} 
/** 
* 选择数据库 
* 
* @param unknown_type $dbname 
*/ 
public function select_db($dbname){ 
mysql_select_db($dbname,$this->connid); 
} 
/** 
* 执行SQL语句 
* 
* @param unknown_type $sqlstr 
*/ 
public function query($sqlstr){ 
$query=mysql_query($sqlstr,$this->connid); 
if (!$query){ 
$this->halt('MySQL Query Error', $sqlstr); 
} 
return $query; 
} 
/** 
* 取得一条查询记录 
* 
* @return unknown 
*/ 
public function get_one($sqlstr){ 
$query=$this->query($sqlstr); 
$rs = $this->fetch_array($query); 
$this->free_result($query); 
return $rs ; 
} 
/** 
* 从结果集中取得一行作为关联数组 
* @param resource 数据库查询结果资源 
* @param string 定义返回类型 
* @return array 
*/ 
public function fetch_array($query, $result_type = MYSQL_ASSOC) 
{ 
return mysql_fetch_array($query, $result_type); 
} 
/** 
* 取得前一次 MySQL 操作所影响的记录行数 
* @return int 
*/ 
public function affected_rows() 
{ 
return mysql_affected_rows($this->connid); 
} 
/** 
* 取得结果集中行的数目 
* @return int 
*/ 
public function num_rows($query) 
{ 
return mysql_num_rows($query); 
} 
/** 
* 返回结果集中字段的数目 
* @return int 
*/ 
public function num_fields($query) 
{ 
return mysql_num_fields($query); 
} 
/** 
* 释放结果内存 
* 
* @param unknown_type $query 
* @return bool 
*/ 
public function free_result($query) 
{ 
return mysql_free_result($query); 
} 
/** 
* 取得上一步 INSERT 操作产生的 ID 
* @return int 
*/ 
public function insert_id() 
{ 
return mysql_insert_id($this->connid); 
} 
/** 
* 取得 MySQL 服务器信息 
* 
* @return string 
*/ 
public function version() 
{ 
return mysql_get_server_info($this->connid); 
} 
/** 
* 关闭MYSQL连接 
* 
* @return bool 
*/ 
public function close() 
{ 
return mysql_close($this->connid); 
} 
/** 
* 返回错误字符串 
* 
* @return string 
*/ private function error(){ 
return @mysql_error($this->connid); 
} 
/** 
* 返回错误号 
* 
* @return int 
*/ 
private function errno(){ 
return intval(@mysql_errno($this->connid)) ; 
} 
/** 
* 输出出错信息 
* 
* @param string $message 
* @param string $sql 
*/ 
private function halt($message = '', $sql = ''){ 
exit("MySQL Query:$sql <br> MySQL Error:".$this->error()." <br> MySQL Errno:".$this->errno()." <br> Message:$message"); 
} 
} 
?>

db.php数据库操作接口,定义数据库操作的方法.
<?php 
interface db { function select_db($dbname);//选择数据库 
function query($sqlstr);//执行sql语句 
function get_one($sqlstr);//执行sql语句,只得到一条记录 
function fetch_array($query);//从结果集中取得一行作为关联数组 
function affected_rows();//返回操作所影响的记录行数 
function num_rows($query);//取得结果集中行的数目 
function num_fields($query);//返回结果集中字段的数目 
function free_result($query);//释放资源 
function insert_id();//返回上一次插入记录的ID; 
function version();//数据库版本 
function close();//关闭数据库连接 
} 
?>

db_factory.php数据库工厂类,要实现数据库平台更方便一定要使用这个类
<?php 
/** 
* @author 黄建文 
* @version v1.0 
* @email hjwtp2005@qq.com 
* @example 
* $db=db_factcory::create('MYSQL','localhost','root','admin','emtit'); 
* $sqlstr="SELECT * FROM member WHERE memberid=1"; 
* $db->get_one($sqlstr); 
*/ 
include 'db_mysql.php'; 
class db_factory { 
function db_factory() { 
} 
static function create($type,$dbhost,$username,$password,$dbname='',$dbcharset=''){ 
switch ($type){ 
case 'MYSQL': 
return new db_mysql($dbhost,$username,$password,$dbname,$dbcharset); 
case 'SQLSERVER': 
return new db_sqlserver($dbhost,$username,$password,$dbname,$dbcharset); 
case 'ACCESS': 
return new db_access($dbhost,$username,$password,$dbname,$dbcharset); 
case 'ORACLE': 
return new db_oracle($dbhost,$username,$password,$dbname,$dbcharset); 
} 
return false; 
} 
function __destruct() { 
} 
} 
?>
PHP 相关文章推荐
开发大型PHP项目的方法
Oct 09 PHP
PHP 5.0 Pear安装方法
Dec 06 PHP
PHP中使用memcache存储session的三种配置方法
Apr 05 PHP
Sublime里直接运行PHP配置方法
Nov 28 PHP
php中Array2xml类实现数组转化成XML实例
Dec 08 PHP
用PHP生成excel文件到指定目录
Jun 22 PHP
php示例详解Constructor Prototype Pattern 原型模式
Oct 15 PHP
谈谈 PHP7新增功能
Dec 16 PHP
Adnroid 微信内置浏览器清除缓存
Jul 11 PHP
php实现session共享的实例方法
Sep 19 PHP
php输出文字乱码的解决方法
Oct 04 PHP
基于PHP+mysql实现新闻发布系统的开发
Aug 06 PHP
php 设计模式之 单例模式
Dec 19 #PHP
PHP 采集程序 常用函数
Dec 18 #PHP
php IP及IP段进行访问限制的代码
Dec 17 #PHP
php mssql 数据库分页SQL语句
Dec 16 #PHP
linux下 C语言对 php 扩展
Dec 14 #PHP
php 文件状态缓存带来的问题
Dec 14 #PHP
快速开发一个PHP扩展图文教程
Dec 12 #PHP
You might like
php项目打包方法
2008/02/18 PHP
如何使用纯PHP实现定时器任务(Timer)
2015/07/31 PHP
PHP实现表单提交数据的验证处理功能【防SQL注入和XSS攻击等】
2017/07/21 PHP
php加速缓存器opcache,apc,xcache,eAccelerator原理与配置方法实例分析
2020/03/02 PHP
表单的焦点顺序tabindex和对应enter键提交
2013/01/04 Javascript
javascript中注册和移除事件的4种方式
2013/03/20 Javascript
javascript写的一个模拟阅读小说的程序
2014/04/04 Javascript
JavaScript中匿名、命名函数的性能测试
2014/09/04 Javascript
详解JavaScript中的every()方法
2015/06/08 Javascript
JS实现可调整倒计时间代码分享
2015/08/18 Javascript
jQuery Html控件基本操作(日常收集整理)
2016/03/11 Javascript
JQuery EasyUI Layout 在from布局自适应窗口大小的实现方法
2016/05/28 Javascript
Jquery 自定义事件实现发布/订阅的简单实例
2016/06/12 Javascript
nodejs构建本地web测试服务器 如何解决访问静态资源问题
2017/07/14 NodeJs
超级简易的JS计算器实例讲解(实现加减乘除)
2017/08/08 Javascript
Node.js中环境变量process.env的一些事详解
2017/10/26 Javascript
JavaScript获取用户所在城市及地理位置
2018/04/21 Javascript
es6新特性之 class 基本用法解析
2018/05/05 Javascript
js 实现watch监听数据变化的代码
2019/10/13 Javascript
vue中使用极验验证码的方法(附demo)
2019/12/04 Javascript
vue在App.vue文件中监听路由变化刷新页面操作
2020/08/14 Javascript
Webpack5正式发布,有哪些新特性
2020/10/12 Javascript
[47:03]Ti4第二日主赛事败者组 LGD vs iG 2
2014/07/21 DOTA
python正则表达式修复网站文章字体不统一的解决方法
2013/02/21 Python
Python多线程threading模块用法实例分析
2019/05/22 Python
Python中拆分字符串的操作方法
2019/07/23 Python
Django-imagekit的使用详解
2020/07/06 Python
python实现取余操作的简单实例
2020/08/16 Python
HTML5中FileReader接口使用方法实例详解
2017/08/26 HTML / CSS
德国旅行、体验和活动的预订平台:Watado
2019/12/04 全球购物
便利店投资的创业计划书
2014/01/12 职场文书
幼儿园元旦活动感言
2014/03/02 职场文书
舞蹈兴趣小组活动总结
2014/07/07 职场文书
乡村教师党员四风问题对照检查材料思想汇报
2014/10/08 职场文书
mysql如何能有效防止删库跑路
2021/10/05 MySQL
Redis如何使用乐观锁(CAS)保证数据一致性
2022/03/25 Redis