我有一些关于在哪里实现缓存部分的想法.你最适合实施的地方在哪里?
在每个模型里面,还是在控制器里?
方法1(伪代码):
// mycontroller.php
MyController extends Controller_class {
function index () {
$data = $this->model->getData();
echo $data;
}
}
// myModel.php
MyModel extends Model_Class{
function getData() {
$data = memcached->get('data');
if (!$data) {
$query->SQL_QUERY("Do query!");
}
return $data;
}
}
方法2:
// mycontroller.php
MyController extends Controller_class {
function index () {
$dataArray = $this->memcached->getMulti('data','data2');
foreach ($dataArray as $key) {
if (!$key) {
$data = $this->model->getData();
$this->memcached->set($key, $data);
}
}
echo $data;
}
}
// myModel.php
MyModel extends Model_Class{
function getData() {
$query->SQL_QUERY("Do query!");
return $data;
}
}
思考:
方法1:
>无多重/多组.如果返回大量的密钥,则会导致开销.
>更容易维护,所有数据库/缓存处理都在每个模型中
方法2:
使用更好的性能 – multiset / multiget
>需要更多代码
>更难维护
告诉我你的想法!