Laravel - 在控制器或模型中构建查询?对于大型网络应用

Posted

技术标签:

【中文标题】Laravel - 在控制器或模型中构建查询?对于大型网络应用【英文标题】:Laravel - Query building in controller or model? For large web apps 【发布时间】:2014-02-25 01:53:27 【问题描述】:

快速的问题,我正在学习 Laravel 4,因为我来自 Codeigniter,我注意到一些 laravel 教程在控制器中有他们的查询,有些在模型中有他们的查询。

我的问题是,我们应该在哪里编写所有查询以获得最佳实践?在控制器或模型中?这与大型 Web 应用程序有关。

非常感谢

【问题讨论】:

【参考方案1】:

最佳做法是在单独的层中编写查询。因此,与您的控制器分开,与您的模型分开。控制器最佳实践还取决于您的项目规模和您对可维护性的具体需求。

一旦您扩大项目规模,请尝试提取更多内容,这样可维护性就不成问题了。围绕用户模型的查询的中间层可能类似于:

class UserRepository 

    public function __construct(Illuminate\Database\DatabaseManager $db)
    
        $this->db = $db;
    

    public function getLatestUsers($limit = 5) 
        //$this->db->table('users')->
    


有关更多最佳实践,您应该查看围绕 laravel 创建的所有资源。喜欢

laracasts nettuts laravel-tricks

【讨论】:

嗯,我以前从未见过这种方法。假设我创建了 UserRepository 类,我会将它存储在哪里?

以上是关于Laravel - 在控制器或模型中构建查询?对于大型网络应用的主要内容,如果未能解决你的问题,请参考以下文章

Laravel 函数属于模型或控制器

是否有必要在 laravel 中为数据库操作创建模型(用于查询构建器)?

Laravel 查询构建器和表名

Laravel 查询生成器返回对象或数组?

向 Laravel 模型查询添加计算字段

Laravel 验证使用 eloquent 或 raw 查询