douwei7501 2018-05-13 01:30
浏览 111
已采纳

Laravel 5.x - Eloquent模型如何成为QueryBuilder?

I am trying to understand how could an Eloquent model also be a query builder. I could not see any polymorphic relationship between Illuminate\Database\Eloquent\Model class and Illuminate\Database\Query\Builder class in the source code. There is no inheritance or interface implementation between these two classes.

So, could anyone please explain how Laravel made it possible for an eloquent model to be a query builder? Thanks in advance.

Edit: I am asking this question because I don't understand how I could call the methods in Builder class through my models, e.g. ModelObject::orderBy('created_at', 'asc')->get(), where orderBy() is a method in Builder class.

  • 写回答

1条回答 默认 最新

  • duanji5746 2018-05-13 01:42
    关注

    There is a query() function on the Eloquent base model which creates a new query builder instance when being called (with the table of the model being already set for the builder). You can find the function here.

    Additionally to that, the magic __call() and __callStatic() functions create a new query builder and delegate the method call to this builder whenever a function is called that is not part of the Eloquent model and which they don't have an implicit call for (like increment(), decrement()). You can find the code for this here.

    So to sum it up: it's magic. The magic functions.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部