日期:2011-09-10 浏览次数:20539 次
从今天开始我们开始介绍模型,模型是一个框架中非常重要的一块儿,控制器实际上不能进行数据的处理,这种处理的过程我们全部放在模型这一块儿来做。
如果是Java,即使是没用框架,它的模型这一块儿也挺复杂的,首先编写service接口,然后写实现,然后定义DAO接口,DAO实现,然后定义这几层之间传输数据的Domain,一般我认为它就是一个POJO。
Java这种契约式的编程方式很不错,即使后面的实现类发生改变,接口没有改变,代码的修改的量也不是很多。
在PHP这一块儿,相对而言就要弱一些,我们如果将这个抽象的太深,那么效率必然会收到影响,抽象的比较浅,模型这一层后期维护又是一个问题。
首先我们先说一下最常用的方式,访问DB,如果只是着眼于单个表,那么就存在表模型,一个表就是一个模型,我们称为DbTable;如果着眼于表与表之间的关联,那么就存在关系模型,我们称为DbRelation。
由于DbTable只与单个表有关,所以它的操作比较简单,而DbRelation由于处理的是表与表之间的关系,所以比较复杂。
现在我们举一个例子,一个系统有三个角色,管理员,普通用户,游客,而这三个角色的基本信息是相同的,所以DB中相应的有两个表:
1. User表,存放用户的基本信息,假设有以下字段:
uid userName password lid
注:lid在逻辑上是后面我要说的Limits表的外键。
2. Limits表,存放用户的权限信息,有以下字段:
lid limits
limits是一个int类型的值,假设1代表普通用户,2代表管理员,由于游客在User表中没有记录,所以就不记在这个表中。
那么对应的模型有:
表模型有两个:User和Limits。
现在我们以User这个模型来举例,这个类的基本信息如下:
1 | <?php |
2 | class User { |
3 | private $_pk = 'uid'; |