写了一个简单强大的 laravel 的 repository 层

2016-12-29 10:12:44 +08:00
 zhaohehe

https://github.com/zhaohehe/z-repository

4251 次点击
所在节点    问与答
6 条回复
ss098
2016-12-29 10:52:00 +08:00
心疼,摸摸。

蛮好的,第一个给你点了星星。
wenymedia
2016-12-29 11:28:15 +08:00
之前看到一个类似的…
jswh
2016-12-29 11:29:58 +08:00
我一直不太明白 repository 层存在的意义,觉得没有必要,但是很多 ORM 都会增加这一层。可能是因为我不太喜欢 Model -> Table ,而是喜欢 Table -> Model 的模型定义过程吧。 Laravel 的也是这样的,所以他的 migration 里面提供数据库表的定义工具,并且根据这个自动生成 Model ,而不是根据 Model 来生成 Table 。失去了 Table 定义的功能,再由 Repository 来接管所有的 CURD, Model 层的功能就太单薄了,调用起来还麻烦。

Laravel 有抽象的 CURD 层,但把功能的入口点都绑在了 Model 身上,比如->query()方法,比如 collection ,或者说 Laravel 的 Model 本质是个 Repository ,省掉了 new Repository(Model) 的过程。
jswh
2016-12-29 11:32:53 +08:00
@jswh 不小心发出去了。所以我的结论是,给 Laravel 加 repository 是画蛇添足,没有必要。个人浅见,大家一起讨论
zhaohehe
2016-12-30 09:46:14 +08:00
@jswh 我觉得 model 本身已经定义了一些和表本身相关的东西,比如 relationship 之类的,有时候需要对数据库进行比较复杂的操作的时候如果再把这些操作也写在 model 里面, model 类就会变得蛮大。这个时候就有必要把对数据库的复杂操作封装好单独拿出来,比如涉及到多个关联表插入的事务。这样 model 类的职责就是单纯的映射到一个表,不提供封装好了的操作,在 repository 里面对数据库的操作除了一般是直接拿到 repository 中的 model 本身进行查询,通过改变 model 对象,来改变 model 的查询结果。这样做还有一个好处就是以后要是引入了其他类型的数据库,比如 mogodb ,就不需要在 controller 里面去修改,不去动核心的业务逻辑,去修改 repository 就好, repository 本身是被接口限制的,所以可以很好的解开耦合。
我个人觉得 repository 还有一个好处就是把查询条件和结果的 transform 也集成进来,这样可以大大减少 controller 里面的代码,让业务逻辑更加清晰,出了 bug 也可以快速将范围缩小到某一个局部。
zhaohehe
2016-12-30 09:46:33 +08:00
@ss098 谢谢 😆

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/330919

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX