PHP程序的一次重构记录
项目和新需求:
我们有一个PHP写的webmail系统,有一个mail_list.php用于展现用户的邮件列表这个页面支持folderId参数(因为邮件是存在不同的文件夹下的)由于邮件太多所以支持翻页。现在需要在系统里增加标签。细化下来:需要在原有的邮件列表里增加标签列,和支持tagid检索出一个邮件列表(列表里也增加标签列)
代码和新需求
mail_list.php调用GetMailList函数,这个函数传入文件夹ID,页码,页大小,得到HTML TABLE和导航链接
GetMailList用T_Page类得到请求的一页数据再处理为HTML表格
虽然T_Page只支持单表查询,但是在整个系统里还是被广泛使用
因为动T_Page还是有风险的,所以最好继承它,然后让需要多表查询的地方直接实例化子类
重构前
/*
功能:查询指定文件夹下的特定页的邮件列表(HTML Table)
*/
function GetMailList($folderId, $pageNo, $pageSize)
{
global $db_obj, $pageLink, $html; // db_obj是从外部导入使用,后两个似乎要导出去 $query = " where folderId = $folderId ..."; //省略很多行
$pageclass = new T_Page;
$tableName = "mail";
$condition = $query . "order by tm desc";
$pageclass->BaseSet($tableName, "id,sender,subject,content,...", $pageNo, $pageSize, $db_obj);
$pageclass->SetCondition($condition); $record = $pageclass->ReadList(); // 查出来的记录集,被放到二维数组里
$pageLink=$pageclass->Page(); //存放翻页按钮的数组 $html = "<table>";
for($ipage=0;$ipage<$pageSize;$ipage++)
{
$i=$ipage; $id = $record[$i]["id"];
$sender = $record[$i]["sender"];
$subject = $record[$i]["subject"];
$content = $record[$i]["content"]; $html = $html . "<tr><td><input type=\"checkbox\" value=\"$id\"></td>";
$html = $html . "<td>$subject</td>";
...
}
$html = $html . "</table>";
}
/*
功能: 查询"一页"记录,且输出导航链接用于翻页
*/
class T_Page
{
var $TableName;
... function BaseSet($TableName, $Fields, $PageNo, $PageSize, $Obj_DB)
{
$this->TableName = $TableName;
... $this->MaxLine = $this->PageSize;
$this->Offset = $this->PageNo * $this->PageSize;
} function SetCondition($Condition)
{
$this->Condition = $Condition;
} function ReadList()
{
$SQL = "select count(*) as recordtotal from $this->tableName $this->Condition";
$result = $this->Obj_DB->simpleQuery($SQL);
$row = $this->Obj_DB->fetchRow($result, DB_FETCHMODE_ASSOC);
$this->Total = $row["recordtotal"]; if($this->Total > 0)
{
$SQL = "select $this->Fields fom $this->tableName $this->Condition limit $this->Offset, $this->MaxLine;";
$result = $this->Obj_DB->simpleQuery($SQL);
$this->Number = $this->Obj_DB->numRows($result); while($row = $this->Obj_DB->fetchRow($result,DB_FETCHMODE_ASSOC))
{
$this->Result[]=$row;
}
$this->Obj_DB->freeResult($result);
}
return($this->Result)
} function Page()
{
if($this->PageNo > 0)
$this->PageLink[0] = "<a ...>上一页</a>";
else
$this->PageLink[0] = "<a>上一页</a>";
...
return $this->PageLink;
} // more function
}
重构后
class MailPage extends T_Page
{
function setTotal()
{
...
$this->Total = $row["recordtotal"];
} function getMailList()
{
$Fields = $this->Field . " ,'' as taglist ";
$SQL.="select $Fields from $this->Table $this->Condition";
$SQL.=" LIMIT $this->Offset , $this->MaxLine"; ...
} function addTagList()
{
...
$tagList = Array();
for($i=0; $i < $this->Number; $i++)
{
$key = $this->Result[$i]["id"];
$this->Result[$i]["taglist"] = $tagList[$key];
}
} //覆盖父类的接口
function ReadList()
{
$this->setTotal();
$this->getMailList();
$this->addTagList();
return $this->Result;
}
} class TagPage extends MailPage
{
function SetCondition($taglist)
{
...
$this->Condition = sprintf(" where id in (%s) order by tm desc ", $mailList);
}
}
PHP程序的一次重构记录的更多相关文章
- XE 的程序升级 XE5 问题处理记录
XE 的程序升级 XE5 问题处理记录 1. [dcc32 Fatal Error] frxClass.pas(3556): F1026 File not found: 'xxxxx\Registr ...
- Linux 系统运行着许多子系统和应用程序。您可以使用系统日志记录从启动时就收集有关运行中系统的数据。有时
概述 在本教程中,您将学习以下内容: 配置 syslog 守护程序 了解标准设施.优先级和操作 配置日志轮换 了解 rsyslog 和 syslog-ng 系统内部发生了什么 Linux 系统运行着许 ...
- MVC应用程序的jQuery代码重构
先看看这篇<在jQuery定义自己函数>http://www.cnblogs.com/insus/p/3415444.html 程序越看越是有重构的地方. 先看1部分,由于在#16代码有宣 ...
- #华为云·寻找黑马程序员#【代码重构之路】如何“消除”if/else
1. 背景 if/else是高级编程语言中最基础的功能,虽然 if/else 是必须的,但滥用 if/else,特别是各种大量的if/else嵌套,会对代码的可读性.可维护性造成很大伤害,对于阅读代码 ...
- 华为云·寻找黑马程序员#【代码重构之路】如何“消除”if/else【华为云技术分享】
1. 背景 if/else是高级编程语言中最基础的功能,虽然 if/else 是必须的,但滥用 if/else,特别是各种大量的if/else嵌套,会对代码的可读性.可维护性造成很大伤害,对于阅读代码 ...
- 记一次百万行WPF项目代码的重构记录
此前带领小组成员主导过一个百万行代码上位机项目的重构工作,分析项目中存在的问题做了些针对性的优化,整个重构工作持续了一年半之久. 主要针对以下问题: 1.产品型号太多导致代码工程的分支太多,维护时会产 ...
- 最简单的记录程序运行时间的方法:[记录PHP程序运行消耗时间]
比较实用的debug方法:具体参考地址已经记不清了,这里重写成类方便调用 /** * @author logonmy@126.com * @Date: 13-7-23 * @desc example ...
- 微信小程序开发之带搜索记录的搜索框
实现功能:点击搜索框,有搜索记录时以下拉菜单显示,点击下拉子菜单,将数据赋值到搜索框,点击搜索图标搜索,支持清空历史记录,可手动输入和清空查询关键字, UI: wxml: <!--查询历史记录数 ...
- 编写第一个Linux环境下程序的编译,下载记录
跟着韦东山学习Linux: 今天系统系统性的学了代码的编译下载,条记录一下: 一,代码:001_led_on.S,就把下面代码编译后Bin文件下载进2440处理器. /* * 点亮LED1: gpf4 ...
随机推荐
- Linux 下mysql忘记root密码解决方法
忘记root密码怎么办:1.关闭数据库2.使用-->mysqld_safe --skip-grant-tables &--<启动数据库3.使用空密码进入数据库(mysql命令后直接 ...
- Scala中class和object的区别
1.class scala的类和C#中的类有点不一样,诸如: 声明一个未用priavate修饰的字段 var age,scala编译器会字段帮我们生产一个私有字段和2个公有方法get和set ,这和C ...
- Asp.NET获取文件及其路径
[相对路径] Request.ApplicationPath /src Path.GetDirectoryName(HttpContext.Current.Request.RawUrl ) //s ...
- magento 常用方法集锦
1,获得store的配置变量 Mage::getStoreConfig('sectionname/groupname/fields'); 1 Mage::getStoreConfig('section ...
- YII数据库操作(CURD操作)
数据库操作 获得模型对象 $model = 模型名::model();或$model = new 模型名(); 1.查询多条记录(返回值:二维数组) $result = $model->find ...
- C#高级
程序集 程序集概念: 程序集是.net中的概念. .net中的dll与exe文件都是程序集.(exe与dll的区别(exe有程序主入口,可以执行,dll没有主入口,不可运行)) 程序集(Assembl ...
- Android----二维码开发
Android----二维码开发 本文为原创,转载请注明出处:http://www.cnblogs.com/xiaobaicai12138/p/5644244.html 一.工具 谷歌的zxing 不 ...
- 几种工具反编译被编译好的DLL文件
我们平时在工作中经常会遇到一些已经被编译后的DLL,而且更加麻烦是没有源代码可以进行修改,只能针对这个DLL的文件进行修改才能得到我们想要的结果:本文将通过一个实例来演示如果完成一个简单的修改;我们将 ...
- 华为j2ee面试题
http://blog.csdn.net/chow__zh/article/details/7741312 java基础1.垃圾回收的优点和原理. Java语言中一个显著的特点就是引入了垃圾 ...
- iOS 图片按比例压缩,指定大小压缩
使用系统方法UIImageJPEGRepresentation(UIimage *image,CGFloat quality)进行图片质量压缩,暂且叫参数quality为压缩比吧,取值范围为0-1. ...