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
Oct 09 PHP
php URL验证正则表达式
Jul 19 PHP
PHP小教程之实现链表
Jun 09 PHP
php实现的Cookies操作类实例
Sep 24 PHP
微信公众平台消息接口校验与消息接口响应实例
Dec 23 PHP
php中注册器模式类用法实例分析
Nov 03 PHP
PHP创建word文档的方法(平台无关)
Mar 29 PHP
Yii模型操作之criteria查找数据库的方法
Jul 15 PHP
PHP实现对xml的增删改查操作案例分析
May 19 PHP
php插入mysql数据返回id的方法
May 31 PHP
PHP内置函数生成随机数实例
Jan 18 PHP
PHP使用Session实现上传进度功能详解
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
收音机发烧友应当熟知的100条知识
2021/03/02 无线电
php中文本数据翻页(留言本翻页)
2006/10/09 PHP
PHP不用递归实现无限分级的例子分享
2014/04/18 PHP
PHP+AJAX实现投票功能的方法
2015/09/28 PHP
Zend Framework动作助手FlashMessenger用法详解
2016/03/05 PHP
详解Yii2 定制表单输入字段的标签和样式
2017/01/04 PHP
PHP生成(支持多模板)二维码海报代码
2018/04/30 PHP
PHP生成指定范围内的N个不重复的随机数
2019/03/18 PHP
php反射学习之不用new方法实例化类操作示例
2019/06/14 PHP
yii2.0框架多模型操作示例【添加/修改/删除】
2020/04/13 PHP
一些易混淆且不常用的属性,希望有用
2007/01/29 Javascript
javascript 对象比较实现代码
2009/04/27 Javascript
分享一个我自己写的ToolTip提示插件(附源码)
2013/01/20 Javascript
JS下载文件|无刷新下载文件示例代码
2014/04/17 Javascript
jQuery实现鼠标选文字发新浪微博的方法
2016/04/02 Javascript
Javascript 获取鼠标当前的位置实现方法
2016/10/27 Javascript
jQuery中的deferred对象和extend方法详解
2017/05/08 jQuery
学习使用Bootstrap页面排版样式
2017/05/11 Javascript
老生常谈js中的MVC
2017/07/25 Javascript
vue子组件改变父组件传递的prop值通过sync实现数据双向绑定(DEMO)
2020/02/01 Javascript
vue实现编辑器键盘抬起时内容跟随光标距顶位置向上滚动效果
2020/05/28 Javascript
Python Requests安装与简单运用
2016/04/07 Python
详解python3中tkinter知识点
2018/06/21 Python
Python netmiko模块的使用
2020/02/14 Python
如何使用python切换hosts文件
2020/04/29 Python
pytorch 移动端部署之helloworld的使用
2020/10/30 Python
详解HTML5 录音的踩坑之旅
2017/12/26 HTML / CSS
英国在线房屋中介网站:Yopa
2018/01/09 全球购物
公司成立感言
2014/01/11 职场文书
社区工作者先进事迹
2014/01/18 职场文书
低碳生活倡议书
2014/04/14 职场文书
2014年党员加强作风建设思想汇报
2014/09/15 职场文书
县委务虚会发言材料
2014/10/20 职场文书
2014年小学图书室工作总结
2014/12/09 职场文书
iPhone13 Pro外观确定,升级4800万镜头,4月20日发新品
2021/04/15 数码科技
Python数据分析之pandas读取数据
2021/06/02 Python