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 相关文章推荐
一个简单计数器的源代码
Oct 09 PHP
php5新改动之短标记启用方法
Sep 11 PHP
利用curl抓取远程页面内容的示例代码
Jul 23 PHP
php实现的一个很好用HTML解析器类可用于采集数据
Sep 23 PHP
PHP编程中的__clone()方法使用详解
Nov 27 PHP
php cookie用户登录的详解及实例代码
Jan 03 PHP
PHP memcache在微信公众平台的应用方法示例
Sep 13 PHP
Laravel框架模板继承操作示例
Jun 11 PHP
PHP基于面向对象封装的分页类示例
Mar 15 PHP
详解PHP PDO简单教程
May 28 PHP
apache集成php7.3.5的详细步骤
Jun 20 PHP
解决php用mysql方式连接数据库出现Deprecated报错问题
Dec 25 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
Yii学习总结之安装配置
2015/02/22 PHP
thinkPHP简单调用函数与类库的方法
2017/03/15 PHP
PHP编程计算文件或数组中单词出现频率的方法
2017/05/22 PHP
PHP封装的完整分页类示例
2018/08/21 PHP
用JQuery 实现的自定义对话框
2007/03/24 Javascript
理解JavaScript的caller,callee,call,apply
2009/04/28 Javascript
jquery中dom操作和事件的实例学习 仿yahoo邮箱登录框的提示效果
2011/11/30 Javascript
Javascript查询DBpedia小应用实例学习
2013/03/07 Javascript
node.js中的console.timeEnd方法使用说明
2014/12/09 Javascript
JavaScript中函数表达式和函数声明及函数声明与函数表达式的不同
2015/11/15 Javascript
js判断文本框输入的内容是否为数字
2015/12/23 Javascript
JS+Canvas实现的俄罗斯方块游戏完整实例
2016/12/12 Javascript
Angular4学习笔记router的简单使用
2018/03/30 Javascript
JavaScript防止全局变量污染的方法总结
2018/08/02 Javascript
Bootstrap模态对话框中显示动态内容的方法
2018/08/10 Javascript
详解小程序rich-text对富文本支持方案
2018/11/28 Javascript
小程序getLocation需要在app.json中声明permission字段
2019/04/04 Javascript
Node.js 的 GC 机制详解
2019/06/03 Javascript
小程序和web画三角形实现解析
2019/09/02 Javascript
vue实现网络图片瀑布流 + 下拉刷新 + 上拉加载更多(步骤详解)
2020/01/14 Javascript
解决微信小程序scroll-view组件无横向滚动的问题
2020/02/04 Javascript
在Angular中实现一个级联效果的下拉框的示例代码
2020/05/20 Javascript
[48:37]EG vs OG 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
在Python下利用OpenCV来旋转图像的教程
2015/04/16 Python
解决python3 HTMLTestRunner测试报告中文乱码的问题
2018/12/17 Python
对python 中class与变量的使用方法详解
2019/06/26 Python
解决Python对齐文本字符串问题
2019/08/28 Python
一文带你了解Python 四种常见基础爬虫方法介绍
2020/12/04 Python
使用CSS3来匹配横屏竖屏的简单方法
2015/08/04 HTML / CSS
CSS3 实现飘动的云朵动画
2020/12/01 HTML / CSS
Under Armour安德玛德国官网:美国高端运动科技品牌
2019/03/09 全球购物
小学数学课后反思
2014/04/23 职场文书
2014党的群众路线教育实践活动总结报告
2014/10/31 职场文书
行政二审代理词
2015/05/25 职场文书
小学感恩主题班会
2015/08/12 职场文书
如何用 Python 子进程关闭 Excel 自动化中的弹窗
2021/05/07 Python