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 相关文章推荐
用DBSQL类加快开发MySQL数据库程序的速度
Oct 09 PHP
PHP 配置文件中open_basedir选项作用
Jul 19 PHP
破解图片防盗链的代码(asp/php)测试通过
Jul 02 PHP
ThinkPHP采用模块和操作分析
Apr 18 PHP
简单实用的.net DataTable导出Execl
Oct 28 PHP
常见的四种POST 提交数据方式(小总结)
Oct 08 PHP
py文件转exe时包含paramiko模块出错解决方法
Aug 12 PHP
Zend Framework数据库操作方法实例总结
Dec 11 PHP
php实现PDO中捕获SQL语句错误的方法
Feb 16 PHP
PHP自定义序列化接口Serializable用法分析
Dec 29 PHP
ThinkPHP框架整合微信支付之JSAPI模式图文详解
Apr 09 PHP
Thinkphp 框架扩展之类库扩展操作详解
Apr 23 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
漂亮但不安全的CTB
2006/10/09 PHP
浅谈php优化需要注意的地方
2014/11/27 PHP
PHP封装的XML简单操作类完整实例
2017/11/13 PHP
bindParam和bindValue的区别以及在Yii2中的使用详解
2018/03/12 PHP
PHP从零开始打造自己的MVC框架之路由类实现方法分析
2019/06/03 PHP
简单谈谈javascript Date类型
2015/09/06 Javascript
JS对象深度克隆实例分析
2017/03/16 Javascript
JS设计模式之惰性模式(二)
2017/09/29 Javascript
总结javascript三元运算符知识点
2018/09/28 Javascript
jQuery无冲突模式详解
2019/01/17 jQuery
详解关于Vue单元测试的几个坑
2020/04/26 Javascript
在Python的Django框架中实现Hacker News的一些功能
2015/04/17 Python
Python实现扫描局域网活动ip(扫描在线电脑)
2015/04/28 Python
Python脚本获取操作系统版本信息
2016/12/17 Python
python实现在IDLE中输入多行的方法
2018/04/19 Python
关于python列表增加元素的三种操作方法
2018/08/22 Python
Python 从相对路径下import的方法
2018/12/04 Python
Python学习笔记之Django创建第一个数据库模型的方法
2019/08/07 Python
Django中从mysql数据库中获取数据传到echarts方式
2020/04/07 Python
TensorFlow Autodiff自动微分详解
2020/07/06 Python
python报错TypeError: ‘NoneType‘ object is not subscriptable的解决方法
2020/11/05 Python
行政主管岗位职责
2013/11/18 职场文书
大学毕业通用个人的求职信
2013/12/08 职场文书
索桥的故事教学反思
2014/02/06 职场文书
党员自我批评与反省材料
2014/02/10 职场文书
出纳员岗位责任制
2014/02/11 职场文书
《锄禾》教学反思
2014/04/08 职场文书
《火烧云》教学反思
2014/04/12 职场文书
森林防火宣传标语
2014/06/27 职场文书
受伤赔偿协议书
2014/09/24 职场文书
2014年卫生院工作总结
2014/12/03 职场文书
社区母亲节活动总结
2015/02/10 职场文书
调任通知
2015/04/21 职场文书
2015年事业单位工作总结
2015/04/27 职场文书
小人国观后感
2015/06/11 职场文书
RPM包方式安装Oracle21c的方法详解
2021/08/23 Oracle