php方法放模型还是控制器,Redis放在控制器还是模型层?

关于Redis在项目中的使用位置,讨论集中在将其置于控制器还是模型层。一种观点主张将Redis操作放在控制器中,保持模型独立,控制器负责协调;另一种观点则建议将Redis逻辑放入模型层,简化控制器调用,提高数据处理的统一性。多数倾向于模型层,认为这样有利于维护和逻辑封装,减少控制器的复杂性,并遵循数据操作应与存储介质无关的原则。
摘要由CSDN通过智能技术生成

在实际项目中,Redis大部分情况下应该放在控制器还是模型?

目前只做过两种方案:

控制器中:

大致的逻辑如下(不要纠结于方法名称):

class UserController extends Controller {

public function index()

{

$userRedis = new UserRedis();

if (!$userInfo = $userRedis->find(['id' => 1000])) {

$user = new User();

$userInfo = $user->find(['id' => 1000]);

$userRedis->save($userInfo);

}

return $userInfo;

}

}

在这种情况下,模型还是独立存在的,数据库模型依然直接读取数据库,Redis模型读取Redis,两者互不影响,控制器从中协调。

模型:

class UserModel extends Model

{

public function find($conditions)

{

$userRedis = new UserRedis();

if (!$userInfo = $userRedis->find($conditions)) {

$userInfo = $this->find($conditions);

$userRedis->save($userInfo);

}

return $userInfo;

}

}

在这种情况下,控制器只需要调用一次接口方案,而无需关心内部实现,整个数据逻辑交给模型来处理。

在项目中实际用过Redis的朋友路过顺便分享一下自己的经验,大家集思广益一下。^_^

回复内容:

在实际项目中,Redis大部分情况下应该放在控制器还是模型?

目前只做过两种方案:

控制器中:

大致的逻辑如下(不要纠结于方法名称):

class UserController extends Controller {

public function index()

{

$userRedis = new UserRedis();

if (!$userInfo = $userRedis->find(['id' => 1000])) {

$user = new User();

$userInfo = $user->find(['id' => 1000]);

$userRedis->save($userInfo);

}

return $userInfo;

}

}

在这种情况下,模型还是独立存在的,数据库模型依然直接读取数据库,Redis模型读取Redis,两者互不影响,控制器从中协调。

模型:

class UserModel extends Model

{

public function find($conditions)

{

$userRedis = new UserRedis();

if (!$userInfo = $userRedis->find($conditions)) {

$userInfo = $this->find($conditions);

$userRedis->save($userInfo);

}

return $userInfo;

}

}

在这种情况下,控制器只需要调用一次接口方案,而无需关心内部实现,整个数据逻辑交给模型来处理。

在项目中实际用过Redis的朋友路过顺便分享一下自己的经验,大家集思广益一下。^_^

优先模型层个人觉得似乎是比较好一点的方法,不论是维护还是逻辑

一般都放数据模型层吧

一般还是说放到模型层,然后封装一个方法,业务层在调用的时候,直接去调取方法就好了,而不用想着再去做缓存的事情。因为缓存在模型层都帮忙给做了。

只要跟数据读写有关的,还是放模型层比较合适

是我我就放模型层了,控制层控制逻辑流程和返回响应,逻辑复杂了看上去不会乱

放 Model 层。

原则:尽量屏蔽具体存储介质的差异。

Mysql、redis 对于项目都只是存储数据的,在代码里面应该不要钱解决存哪,提供统一的调用方式, UserMysql.find()、UserRedis.find();

或者

User.find(),

User.findFromRedis() 默认调用从 mysql 读取,redis 操作折提供其他的函数

这个也是 ORM 的思想。

这取决于你的Model是否就等于数据库。

因为从你的$this->find来看,似乎是直接把Model的$this当做了数据库?

有两种选择:

不要把Model本身直接定义为数据库,而在Model里用redis和db类分别操作。如果redis和db里的操作都很少很简单,可以选择这样。

把Model定位为数据操作层,叫UserDbModel(对应你现在的UserModel),再定义另一个Model叫UserRedisModel(对应你现在的$userRedis),让两者地位平等,同时在Model层上加一层Logic层,处理缓存与数据库的关系,Controller变为只能调用Logic层。这种方式是我现在在用的,对复杂的逻辑而言可以显得更清晰。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值