欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

PHP MVC的M,应该是写C所要调用的业务逻辑方法,还是访问数据库的方法?

程序员文章站 2024-02-20 11:59:04
...
或者,两者都包括在这里?

回复内容:

或者,两者都包括在这里?

个人觉得如果业务不复杂的话,把业务逻辑写在model层,C层只写简单的调度...
曾经大量的代码与逻辑写在C层,但复用性很差,比如前台与后台要调用一个业务的逻辑基本相似,写在C层就感觉很冗余
如果业务复杂,可以再单独分个层专门处理这些逻辑,M层就负责与数据相关的存储即可.

主要看你的业务和代码代码约定,没有固定的用处,要灵活运用。

个人建议每个Model数据模型对应特定的数据表,处理单独的数据表业务,逻辑是业务的实现方式,按照业务去封装,这样便于维护。

M是数据模型,对于C来讲M就相当于是数据库的一张表,只负责存取数据,业务逻辑完全在C中实现,C告诉M存什么数存哪些字段,M负责生成并执行相应的SQL语句然后向C报告结果。

两者皆可。你可以把围绕Model的常见操作写成相应Model类的方法,也可以把它们作为业务逻辑写到Controller的Action里去。

我一般把操作围绕单个Model的CRUD模块直接写成方法,这样在多个Controller里调用(Controller要负责错误提示输出);涉及多个Model的复杂事务,则完全写在控制器中。

业务逻辑全部放到C层,C层的职责显得太多了,C层专门调用M和V

相关标签: php mvc