我们在使用php的时候遇到一个问题
比如我现在有三张表
用户表: user
商品表: goods
代金券: ticket
用户地址: address
由此就对应了三个对象
user, goods, ticket, address
我现在有几个功能:取得用户的代金券, 取得用户的可用代金券, 取得用户的地址列表, 取得用户所购买的商品
我现在是这么做的
<code class="php">class User extends Model{
public function oder()
{
return OrderRepository::getByUserId($this->id);
}
public function successOrder()
{
return OrderRepository::getSuccessByUserId($this->id);
}
public function cancelOrder()
{
return OrderRepository::getCancelByUserId($this->id);
}
public function address()
{
return AddressRepository::getByUserId($this->id);
}
...
}</code>为什么这样做呢, 我觉得和用户紧密相关的操作放到用户对象中比较合理! 单这个感觉冗余的挺多的, 大家一般都是怎么整理的呢!感觉也有可能会造成User类过大!
大家一般都是怎么处理的呢?
我们在使用php的时候遇到一个问题
比如我现在有三张表
用户表: user
商品表: goods
代金券: ticket
用户地址: address
由此就对应了三个对象
user, goods, ticket, address
我现在有几个功能:取得用户的代金券, 取得用户的可用代金券, 取得用户的地址列表, 取得用户所购买的商品
我现在是这么做的
<code class="php">class User extends Model{
public function oder()
{
return OrderRepository::getByUserId($this->id);
}
public function successOrder()
{
return OrderRepository::getSuccessByUserId($this->id);
}
public function cancelOrder()
{
return OrderRepository::getCancelByUserId($this->id);
}
public function address()
{
return AddressRepository::getByUserId($this->id);
}
...
}</code>为什么这样做呢, 我觉得和用户紧密相关的操作放到用户对象中比较合理! 单这个感觉冗余的挺多的, 大家一般都是怎么整理的呢!感觉也有可能会造成User类过大!
大家一般都是怎么处理的呢?
model分类:
user model 只放用户相关的
order model 只放订单相关的
立即学习“PHP免费学习笔记(深入)”;
注意业务要拆分,解耦合
也可以拆分为Logic逻辑层、model数据层、service服务层这样的
各个表获取数据的方法写在各自的Model类里,要从多个数据表中取数据的话,在控制器里分别实例化表对应的Model,并分别调用各自的方法获取数据,在Controller里将数据整合。
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号