分类:
2009-06-03 17:41:16
/**
* 一个用来访问MySQL的类
* 仅仅实现演示所需的基本功能,没有容错等
* 代码未作修改,只是把注释翻译一下,加了点自己的体会
*/
class DataAccess {
var $link_id; //用于存储数据库连接
var $query_id; //用于存储查询源
//! 构造函数.
/**
* 创建一个新的DataAccess对象
* @param $host 数据库服务器名称
* @param $user 数据库服务器用户名
* @param $pass 密码
* @param $db 数据库名称
*/
function __construct($host,$user,$pass,$db) {
$this->link_id=mysql_pconnect($host,$user,$pass); //连接数据库服务器
mysql_select_db($db,$this->link_id); //选择所需数据库
mysql_query("set names utf8;");
}
//! 执行SQL语句
/**
* 执行SQL语句,获取一个查询源并存储在数据成员$query中
* @param $sql 被执行的SQL语句字符串
* @return void
*/
function query($sql) {
$this->query_id=mysql_unbuffered_query($sql,$this->link_id); // Perform query here
if ($this->query_id) return true;
else return false;
}
//! 获取结果集
/**
* 以数组形式返回查询结果的所有记录
* @return mixed
*/
function fetchRows($sql) {
$this->query($sql);
$arr=array();
$i=0;
while( $row=mysql_fetch_array($this->query_id,MYSQL_ASSOC) )
//MYSQL_ASSOC参数决定了数组键名用字段名表示
{ $arr[$i]=$row;
$i++;
}
return $arr;
}
}
?>
//! Model类
/**
* 它的主要部分是对应于留言本各种数据操作的函数
* 如:留言数据的显示、插入、删除等
*/
class Model {
var $dao; //DataAccess类的一个实例(对象)
//! 构造函数
/**
* 构造一个新的Model对象
* @param $dao是一个DataAccess对象
* 该参数以地址传递(&$dao)的形式传给Model
* 并保存在Model的成员变量$this->dao中
* Model通过调用$this->dao的fetch方法执行所需的SQL语句
*/
function __construct(&$dao) {
$this->dao=$dao;
}
function listNote() { //获取全部留言
$notes=$this->dao->fetchRows("SELECT * FROM note ORDER BY timedate DESC");
return $notes;
}
function postNote() { //插入一条新留言
$name=$_POST['username'];
$email=$_POST['email'];
$content=$_POST['content'];
$timedate=time()+8*3600;
$sql="INSERT INTO note (name, email, content, timedate) VALUES
('".$name."', '".$email."', '".$content."', '".$timedate."' )";
//echo $sql; //对于较复杂的合成SQL语句,
//调试时用echo输出一下看看是否正确是一种常用的调试技巧
if ($this->dao->query($sql)) return true;
else return false;
}
function deleteNote() { //删除一条留言,$id是该条留言的id
$sql="DELETE FROM note WHERE id=".$_GET['id'];
if ($this->dao->query($sql)) return true;
else return false;
}
}
?>
require_once('lib/DataAccess.php');
require_once('lib/Model.php');
$dao=& new DataAccess ('localhost','root','password','test');
$model=& new Model($dao);
$notes=$model->listNote();
……
?>
//! Controller
/**
* 控制器将$_GET['action']中不同的参数(list、post、delete)
* 对应于完成该功能控制的相应子类
*/
class Controller {
var $model; // Model 对象
var $view; // View 对象
//! 构造函数
/**
* 构造一个Model对象存储于成员变量$this->model;
*/
function __construct (& $dao) {
$this->model=& new Model($dao);
}
function getView() { //获取View函数
//返回视图对象view
//对应特定功能的Controller子类生成对应的View子类的对象
//通过该函数返回给外部调用者
return $this->view;
}
}
//用于控制显示留言列表的子类
class listController extends Controller{ //extends表示继承
function __construct (& $dao) {
parent::__construct($dao); //继承其父类的构造函数
//该行的含义可以简单理解为:
//将其父类的构造函数代码复制过来
$notes=$this->model->listNote();
$this->view=& new listView($notes);
//创建相应的View子类的对象来完成显示
}
}
//用于控制添加留言的子类
class postController extends Controller{
function __construct (& $dao) {
parent::__construct($dao);
if ($this->model->postNote()) $success=1;
else $success=0;
$this->view=& new postView($success);
}
}
//用于控制删除留言的子类
class deleteController extends Controller{
function __construct (& $dao) {
parent::__construct($dao);
if ($this->model->deleteNote()) $success=1;
else $success=0;
$this->view=& new deleteView($success);
}
}
?>