我们将那些需要在多处调用的查询条件编写过滤器,然后将调用查询代码的地方改为调用过滤器,调用过滤器比编写那些冗长而重复的查询方法更加便捷,可读性也更好。...这样,当我们通过 User 模型类进行查询的时候,就会自动应用全局作用域指定的查询条件了,以 User::all() 为例,我们通过 Telescope 的 「Queries」 页面就能看到对应的 SQL...`deleted_at` is null order by `views` desc 如果我们要把这个 SQL 语句转化为查询构建器的话,显然需要编写多个查询方法,而且如果要在多个地方进行这种查询...,比如我要在文章中查询指定类型的文章,可以通过在 Post 模型类中定义如下方法: public function scopeOfType(Builder $query, $type) { return...`deleted_at` is null 动态作用域的调用和移除方式和局部作用域一样。 本系列教程首发在Laravel学院(laravelacademy.org)
Illuminate\Database\Query\Builder 调用方法去完成整个SQL。...你也可以帮Builder这个类作为整个SQL操作的基类。...orWhere($column, $operator = null, $value = null) public function whereRaw($sql, $bindings = [], $boolean...类,开头我们讲过这个类了,这里就不多说了,随后就是各种sql的拼接->执行sql->结束战斗 Eloquent ORM Eloquent ORM 与DB facade 类似,首先每个 Eloquent...new Builder($query); } 最后我们到了 Illuminate\Database\Eloquent\Builder 文件下,这个类中涵盖了ORM的基本操作,例如find , findOrFail
\Query\Builder 调用方法去完成整个SQL。...你也可以帮Builder这个类作为整个SQL操作的基类。...orWhere($column, $operator = null, $value = null) public function whereRaw($sql, $bindings = [], $boolean...Builder($query); } 最后我们到了 Illuminate\Database\Eloquent\Builder 文件下,这个类中涵盖了ORM的基本操作,例如find , findOrFail...如果你在代码用到了get方法,抱歉,这里没有,它依旧会通过__call 方法将你的请求转发到 Illuminate\Database\Query\Builder 类中 $this- query- {$method
(), '=', $localValue); } } protected function performJoin(Builder $query = null)...针对这个例子 performJoin为关联添加的join约束为: query->join('users', 'users.id', '=', 'posts.user_id') 添加的where约束为:...$this->query->where('users.country_id', '=', 1) 假设country_id是1 对应的SQL查询是: SELECT * FROM posts INNER JOIN...不过当查询父模型时,Eloquent 可以「预加载」关联数据。预加载避免了 N + 1 查询问题。...模型关联常用的一些功能的底层实现到这里梳理完了,Laravel把我们平常用的join, where in 和子查询都隐藏在了底层实现中并且帮我们把相互关联的数据做好了匹配。
经过一番调研之后发现了一个堪称神器的扩展:laravel-upsert 这个 Laravel 扩展为查询构建器和 Eloquent 添加了对 INSERT & UPDATE (UPSERT) 和 INSERT...的强大,不仅减少了代码量,也减少了sql 查询次数,提升了性能。...sql的条数:优化前5条sql,优化后2条sql laravel-upsert 扩展的特性 安装 composer require staudenmeir/laravel-upsert:"^1.0"...除 SQL Server 外的所有数据库都要求这些列具有PRIMARY或UNIQUE索引。 提供要更新的列作为第三个参数(可选)。默认情况下,将更新所有列。...Lumen 如果您使用 Lumen,则必须手动实例化查询构建器: $builder = new \Staudenmeir\LaravelUpsert\Query\Builder(app('db')->connection
laravel模型为我们提供了一层数据库操作层,将数据交互独立出来。 但是久而久之,随着项目的需求不断扩大,最常用的查询操作,同样会有大量的冗余代码。...events WHERE `published` = 1; 如果条件 published = 1 在默认的情况下需要开启,我们可以使用laravel模型的 全局作用域 方式为所有查询追加上这个条件。...在模型文件 Event 内头部引入下述类: use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\Builder...$builder) { $builder->where('published', '=', 1); }); } 这样SQL语句 where published = 1 就会追加到所有的模型查询方法内...而声明一个本地作用域,只要遵循laravel的语法规定即可,如下示例: public function scopePublished($query) { return $query->where('published
上篇文章我们讲了Database的查询构建器Query Builder, 学习了Query Builder为构建生成SQL语句而提供的Fluent Api的代码实现。...这篇文章我们来学习Laravel Database地另外一个重要的部分: Eloquent Model。...Eloquent Model以上文讲到的Query Builder为基础提供了Eloquent Builder与数据库进行交互,此外还提供了模型关联优雅地解决了多个数据表之间的关联关系。...Builder的where方法在接到调用请求后直接把请求转给来Query Builder的 where方法,然后get方法也是先通过Query Builder的 get方法执行查询拿到结果数组后再通过...Builder的实现细节我们在上一篇文章里已经说过了这里不再赘述,如果好奇Query Builder是怎么执行SQL操作的可以回去翻看上一篇文章。
\Illuminate\Database\Eloquent\Builder类里,如下: /** * Find a model by its primary key....- model- getQualifiedKeyName(), '=', $id); return $this- first($columns); } 由于Eloquent Query Builder...是依赖查询构建器\Illuminate\Database\Query\Builder的,first和get方法的源码在Query Builder里如下: /** * Execute the query...reset($results) : null; } /** * Execute the query as a "select" statement....以上这篇Laravel Eloquent ORM 实现查询表中指定的字段就是小编分享给大家的全部内容了,希望能给大家一个参考。
应用场景 某些SQL语句需要加某些共同的条件,例如status > 0,如果我们每条SQL语句都加的话显然是很麻烦的,作为一个优雅的框架,当然有相应的解决办法 编写作用域 Laravel 应用默认并没有为作用域预定义文件夹...\Eloquent\Builder; use Illuminate\Database\Eloquent\Model; class StatusScope implements Scope...{ /** * Apply the scope to a given Eloquent query builder...* * @param \Illuminate\Database\Eloquent\Builder $builder * @param \Illuminate\...$builder->where('status','>', 1); }); } } 有些查询并不想使用作用域,可以通过调用以下方法移除作用域 ScopeTest::
说明:本文主要学习下Query Builder编译Fluent Api为SQL的细节和执行SQL的过程。...就是SQL语法编译器,用来编译Fluent Api为SQL。...OK, 总的来说,通过了解Query Builder的实现原理后,知道其并不复杂或神秘,只是一个对PDO更友好封装的包裹,Query Builder有几个重要的类或概念:连接类MySqlConnection...那Eloquent ORM又是什么,与Query Builder是什么关系呢?既然有了Query Builder,为何还提供了Eloquent ORM呢?...以后再聊Eloquent ORM的实现原理吧。 总结:本文主要学习了Query Builder编译SQL细节和执行SQL逻辑。后续在分享下Eloquent ORM的实现原理,到时见。
Eloquent Eloquent是laravel中的orm,采取的是active record的设计模式,里面的对象不仅包括领域逻辑,还包括了数据库操作,但是大家平时使用的时候可能没有探究eloquent...初始化 Eloquent首先要对数据库连接做抽象,于是有了Connection类,内部主要是对PDO的一个封装,但是如果只有Connection的话,一个问题是,我们需要直面sql,于是就有了Builder...类,其功能就是屏蔽sql,让我们能用面向对象的方式来完成sql的查询功能,Builder应该是sql builder,此时Eloquent的主要的类就如下: 其中Builder负责sql的组装,Connection...负责具体的数据库交互,其中多出来一个Grammar,其负责主要是负责将Builder里面存储的数据转化为sql。...负责数据库操作,Builder负责面向对象的sql操作,Grammar负责sql的拼装,Eloquent/Model是Active Record模式的核心Model,同时具备领域逻辑和数据库操作功能,其中数据库操作功能是委托给了
这样就可以在查询条件中添加一个全局条件。Laravel中软删除数据的过滤也是使用这种方式实现的。...Laravel远程关联关系通过hasManyThrough实现。里面有两个地方涉及到软删除的查询。...protected function performJoin(Builder $query = null) { $query = $query ?...$query, Builder $parentQuery, $columns = ['*']) { $query->from( $query->getModel()->getTable().' as...以上就是Laravel实现软删除的大概逻辑。这里有一个细节,Laravel中软删除的标记是一个时间格式的字段,默认delete_at。通过是否为null判断数据是否删除。
is_null($sql = $grammar->$method($this, $command))) { $statements = array_merge($statements...Record模式中Model的功能,包括了Model、Builder和Relation功能,忘记的可以去看前一篇orm 系列 之 Eloquent演化历程1的内容 Query:包含了最基本的Sql的操作和语法逻辑...首先是morphMany的构造函数: public function __construct(Builder $query, Model $parent, $morphName) { $this...第二步setAsGlobal,其动作就做了static::$instance = $this,通过将实例设置为静态变量,我们就能在全局通过静态方法来访问Capsule了。...参考 [ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系
继续介绍 Laravel Eloquent 的小技巧 11....但是查询的返回都是一个 Collection 对象,Laravel 为集合提供了很多方便的操作方法,sortBy 就是其中一个,当然还可以用 filter 等集合操作) 12....原生查询方法 有时我们需要在Eloquent语句中添加原生查询语句。 幸运的是,它提供了这样的功能。...正确翻译 SQL 语句中的括号 到 Eloquent 的查询 假设在你的 SQL 查询中 包含了 and / or 这样的关键字,如下: ......正确的方法稍微有些复杂,需要用到闭包函数作为子查询: $q->where(function ($query) { $query->where('gender', 'Male')
事情是这样的,有天写了一个左连接查询,由于表名太长,所以分别给起个别名,代码如下: public function detail() { $result = TakeOrderModel::query...= detail.take_order_id where take_order.delete_time is null 显而易见:软删除查询条件的表名是全名,所以报错了。...分析 软删除作用域 SoftDeletingScope 源码: /** * Apply the scope to a given Eloquent query builder....* * @param \Illuminate\Database\Eloquent\Builder $builder * @param \Illuminate\Database\Eloquent\...以上这篇Laravel 模型使用软删除-左连接查询-表起别名示例就是小编分享给大家的全部内容了,希望能给大家一个参考。
说明:本文主要说明Laravel Eloquent的延迟预加载(Eager Loading),使用延迟预加载来减少MySQL查询次数。同时,会将开发过程中的一些截图和代码黏上去,提高阅读效率。...\Illuminate\Database\Query\Builder|\App\Phone whereUpdatedAt($value) * @mixin \Eloquent */ class Phone...static \Illuminate\Database\Query\Builder|\App\Shop whereUpdatedAt($value) * @mixin \Eloquent */ class...预加载查询 (1)嵌套预加载 Eloquent在通过属性访问关联数据时是延迟加载的,就是只有该关联数据只有在通过属性访问它时才会被加载。在查找上层模型时可以通过预加载关联数据,避免N+1问题。...发现:只有4个query,耗时3.58ms,效率提高很多。把原来的N+1这种query改造成了where..in..这种query,效率提高不少。可以用EXPLAIN来查看SQL语句的执行计划。
,比如我们想要过滤包含评论或标签的文章: $posts = Post::has('comments')->orHas('tags')->get(); 如果你想要通过更复杂的关联查询过滤模型实例,还可以通过...', function ($query) { $query->where('title', 'like', 'Laravel学院%'); })->get(); 底层执行的 SQL 查询语句如下...($query) { $query->where('title', 'like', 'Laravel学院%') ->whereExists(function ($query)...学院」的用户,将 whereExists 换成 orWhereExists 方法即可: $users = User::whereHas('posts', function ($query) {...前提是 user_id 允许为 null,否则会抛出异常。 空对象模型 如果外键字段 user_id 允许为空的话,当我们访问 Post 模型上的 author 属性时,默认返回为 null。
本文实例讲述了laravel框架数据库操作、查询构建器、Eloquent ORM操作。...Laravel将常用的数据库操作封装为接口函数提供给用户调用,从而使数据库操作更为便捷,这些接口就是查询构建器(query builder)。...而且通过PDO绑定的方式避免SQL注入攻击,在使用查询构建器时不必考虑过滤用户输入。...')- when($order,function ($query){ return $query- orderBy('age','desc'); //$order为true时才执行此语句...Eloquent默认的主键为’id’,且该字段为自增int型,如果需要自定义主键,可以通过$primaryKey来指定。
* * @param \Illuminate\Database\Eloquent\Builder $query * @param string...* * @param \Illuminate\Database\Eloquent\Builder $query * @param array...我将debug模式打开,并注释了抑制报错的逻辑,即可在页面上看到SQL注入的报错: 1[3]参数可以注入任何语句,所以这里存在一个SQL注入漏洞。...name=1&1[0]=&1[1]=a&1[2]=&1[3]=or+%27a%27=%3F%20and%201=1)+--+ 将and 1=1修改为and 1=2,数据消失了: http://127.0.0.1...主要是在初始化PDO的时候设置了PDO::ATTR_EMULATE_PREPARES为false,而数据库默认的参数化查询不允许prepare多个SQL语句。
* 将范围应用于给定的 Eloquent 查询生成器 * * @param \Illuminate\Database\Eloquent\Builder $builder...的最后一个参数改为true则查询关联对象本身 通过原生sql语句我们可以更好的理解 当最后一个参数为false时 SQL: select `tags`.*, `media_tags`....`tagtable_type` = 'App\Tag' 关联查询 实际上前面提到的渴求式加载与懒惰式加载也归结于关联查询,这里将关联查询补充完整 当我们以动态属性的方式去访问关联关系时为懒惰式加载 如...提供了便捷的方法将新的模型增加至关联中,如你需要为一个Muser模型插入一个新的Phone,这时你无须为Phone手动设置musers属性,直接在关联上使用save方法插入Phone即可 如: 为用户id...,前提是uid字段允许为空,如果不允许为空会抛出异常 空对象模型 如果外键字段uid允许为空,当我们访问Phone模型上的muser属性(注意这里是属性,而不是方法)时,默认返回null,Eloquent
领取专属 10元无门槛券
手把手带您无忧上云