#1 jake

在数据库操作中,我们经常用到spPager、spLinker、spCache和spVerifier四个spModel的附加类。这里我们就介绍一下这四个类之间的一些关系。



spPager和spLinker的连用——对分页结果进行关联

当需要对分页的结果进行关联查询的时候,就可以使用spPager + spLinker。

$model->spLinker()->spPager(1, 10)->findAll();

请注意顺序,是spLinker再到spPager,而反过来会报错的。
spCache不可以连用,但是可以对封装的函数进行缓存,达到更好的效果
spCache是对函数进行缓存的高效缓存程序。
1.首先是将分页的操作封装起来,在model的子类中封装,这里可以延伸到把其他的数据操作封装起来,比如说一个首页上要同时显示每一个文章分类前六条新文章记录的情况。
class m_mydb extends spModel
{   
        ...
        function getmypage($conditions, $page, $pageSize){
           return $this->spPager($page, $pageSize)->findAll($conditions);
        }
        function getalltext($limit = 6){
          ...  
          return $data;
        }
}
2. 在控制器内就可以使用:
$this->result = spClass('mydb')->spCache(3600)->getmypage("", 1, 10);
$this->pager = spClass('mydb')->spPager()->getPager(); // 由于getmypage内是用spPager来获取数据的,所以getPager同样可用,但是请注意缓存后的页码不一定正确。
$this->alltext = spClass('mydb')->spCache(3600)-> getalltext();

来进行调用了,这是减少数据库操作而增加程序运行速度的一个简单有效的方法。



spVerifier是验证数据,所以不能和其他三个类连用

和其他三个类不同,spVerifier仅作为验证数据,所以不需要连用。


2012-08-04 23:04:20