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+FLASH实现上传文件进度条相关文件 下载
Jul 21 PHP
兼容PHP5的PHP目录管理函数库
Jul 10 PHP
php self,$this,const,static,-&amp;gt;的使用
Oct 22 PHP
PHP类的使用 实例代码讲解
Dec 28 PHP
PHP 获取客户端真实IP地址多种方法小结
May 15 PHP
php共享内存段示例分享
Jan 20 PHP
解决cPanel无法安装php5.2.17
Jun 22 PHP
PHP中Http协议post请求参数
Nov 02 PHP
php自定义时间转换函数示例
Dec 07 PHP
PHP实现的下载远程文件类定义与用法示例
Jul 05 PHP
ThinkPHP实现转换数据库查询结果数据到对应类型的方法
Nov 16 PHP
php5.3/5.4/5.5/5.6/7常见新增特性汇总整理
Feb 27 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将任何格式视频转为flv的代码
2009/09/03 PHP
PHP图片库imagemagick安装方法
2014/09/23 PHP
PHP中使用Session配合Javascript实现文件上传进度条功能
2014/10/15 PHP
PHP合并数组的2种方法小结
2016/11/24 PHP
让ThinkPHP的模板引擎达到最佳效率的方法详解
2017/03/14 PHP
php实现对文件压缩简单的方法
2019/09/29 PHP
一个不错的应用,用于提交获取文章内容,不推荐用
2007/03/03 Javascript
js数组方法扩展实现数组统计函数
2014/04/09 Javascript
JS网页在线获取鼠标坐标值的方法
2015/02/28 Javascript
BootStrap的JS插件之轮播效果案例详解
2016/05/16 Javascript
JavaScript中用let语句声明作用域的用法讲解
2016/05/20 Javascript
js 去掉字符串前后空格实现代码集合
2017/03/25 Javascript
深入解读Node.js中的koa源码
2019/06/17 Javascript
JS获取动态添加元素的方法详解
2019/07/31 Javascript
python技能之数据导出excel的实例代码
2017/08/11 Python
numpy添加新的维度:newaxis的方法
2018/08/02 Python
python在OpenCV里实现投影变换效果
2019/08/30 Python
Python爬虫图片懒加载技术 selenium和PhantomJS解析
2019/09/18 Python
git查看、创建、删除、本地、远程分支方法详解
2020/02/18 Python
利用Python如何实时检测自身内存占用
2020/05/09 Python
python 负数取模运算实例
2020/06/03 Python
使用Keras加载含有自定义层或函数的模型操作
2020/06/10 Python
Python实现定时监测网站运行状态的示例代码
2020/09/30 Python
python实现经纬度采样的示例代码
2020/12/10 Python
数学系个人求职信范文
2014/01/30 职场文书
歌唱比赛策划方案
2014/06/06 职场文书
行政管理专业求职信
2014/07/06 职场文书
企业公益活动策划方案
2014/08/24 职场文书
加强作风建设工作总结
2014/10/23 职场文书
后进基层党组织整改方案
2014/10/25 职场文书
司法局2014法制宣传日活动总结
2014/11/01 职场文书
体检通知范文
2015/04/21 职场文书
人口与计划生育责任书
2015/05/09 职场文书
2016教师校本研修心得体会
2016/01/08 职场文书
Canvas三种动态画圆实现方法说明(小结)
2021/04/16 Javascript
python 判断文件或文件夹是否存在
2022/03/18 Python