搜索
PHP MVC的M,应该是写C所要调用的业务逻辑方法,还是访问数据库的方法?
怪我咯
怪我咯 2017-04-10 16:22:34
[PHP讨论组]

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

怪我咯
怪我咯

走同样的路,发现不同的人生

全部回复(5)
迷茫

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

PHP中文网

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

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

阿神

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

ringa_lee

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

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

伊谢尔伦

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号