首页
学习
活动
专区
圈层
工具
发布

Laravel源码解析之QueryBuilder

提供了一个方便的接口来创建及运行数据库查询语句,开发者在开发时使用QueryBuilder不需要写一行SQL语句就能操作数据库了,使得书写的代码更加的面向对象,更加的优雅。...); $statement->execute(); return $statement->fetchAll(); }); 直到getPdoForSelect这个阶段Laravel...通过梳理流程我们知道: Laravel是在第一次执行SQL前去连接数据库的,之所以$pdo一开始是一个闭包因为闭包会保存创建闭包时的上下文里传递给闭包的变量,这样就能延迟加载,在用到连接数据库的时候再去执行这个闭包连上数据库...到这里QueryBuilder大体的流程就梳理完了,虽然我们只看了select一种操作但其实其他的update、insert、delete也是一样先由QueryBuilder编译完成SQL最后由Connection...实例去执行然后返回结果,在编译的过程中QueryBuilder也会帮助我们进行防SQL注入。

2.3K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    3分钟短文:Laravel模型作用域,为你“节省”更多代码

    laravel模型为我们提供了一层数据库操作层,将数据交互独立出来。 但是久而久之,随着项目的需求不断扩大,最常用的查询操作,同样会有大量的冗余代码。...比如有一个查询条件: $publishedEvents = Event::where('published', '=', 1)->get(); 上述代码最后生成的SQL语句如下: SELECT * FROM...不过就是QueryBuilder的一个属性数组的一个元素而已,手动移除就行了,这样特例问题就解决了。...', 1); } 只需要声明一个以 scope 为首的小驼峰命名的函数方法即可,并返回一个 QueryBuilder 对象实例。...既然本地作用域返回的是 QueryBuilder 实例,那么自然就可以链式调用本地作用域的方法,和 QueryBuilder 的方法。

    1.8K22

    3分钟短文:Laravel查询构造器,告别手写SQL的艰苦岁月

    引言 鉴于上一章标题引起一些开发同学的巨大兴趣,本文我们接着此种行文方式继续我们的“Laravel宇宙”系列文章。...为了演示查询构造器的功能用法,我们直接使用 DB 门面创建 QueryBuilder 对象。...我们引入查询构造器,引入模型,就是为了摆脱繁杂的SQL语法,这里又传入原生语句,不提倡!...,[true]); 为了编程愉悦感,还是回归我们的laravel推荐的链式操作的方式来演示更多更复杂的功能。...写在最后 本文轻描淡写地讲解了laravel中的查询构造器,讲了一个比较复杂的OR查询,因为使用闭包组装WHERE约束条件,所以会有些难以理解, 不过对比打印生成的SQL语句后,大家应该会豁然开朗!

    1.7K10

    3分钟短文:Laravel查询构造器,告别手写SQL的艰苦岁月

    引言 鉴于上一章标题引起一些开发同学的巨大兴趣,本文我们接着此种行文方式继续我们的“Laravel宇宙”系列文章。...为了演示查询构造器的功能用法,我们直接使用 DB 门面创建 QueryBuilder 对象。...我们引入查询构造器,引入模型,就是为了摆脱繁杂的SQL语法,这里又传入原生语句,不提倡!...,[true]); 为了编程愉悦感,还是回归我们的laravel推荐的链式操作的方式来演示更多更复杂的功能。...写在最后 本文轻描淡写地讲解了laravel中的查询构造器,讲了一个比较复杂的OR查询,因为使用闭包组装WHERE约束条件,所以会有些难以理解, 不过对比打印生成的SQL语句后,大家应该会豁然开朗!

    2.2K11

    Laravel源码学习文章汇总

    通过更新文章自己在软件设计、文字表达方面都有所提高,在刚开始决定写Laravel源码分析地文章的时候我地期望是自己和读者通过学习Laravel核心的代码能在软件设计上带来提高,这些提高主要是指两方面:...通过学习Laravel核心的代码来辅助理解软件设计行业中经常提及的核心概念,通过学习像IocContainer、面向对象的五大原则SOLID 是怎么应用到框架设计中去的来指导应该如何去做软件开发设计。...这方面对你的收益应该是跳出Laravel框架和PHP语言层面的,当你需要切换到其他框架和语言时这些收益仍会反馈给你。...Laravel整个框架设计到的内容有很多,其他的组件我也就不再一一去写文章梳理了, 相信你在认真看完这个系列的文章后,假如你在使用其他组件过程中遇到了诡异的问题,或者好奇框架是怎么帮你实现功能的?...类地反射和依赖注入 IocContainer 服务提供者 Facades Route Middleware 控制器 Request Response Database基础 QueryBuilder 模型

    1.1K10

    Laravel源码解析之Database

    EloquentModel, Eloquent是建立在 DB的查询构建器基础之上,对数据库进行了抽象的 ORM,功能十分丰富让我们可以避免写复杂的SQL语句,并用优雅的方式解决了数据表之间的关联关系。...config); //设置time zone $this->configureTimezone($connection, $config); //为数据库会话设置sql...public function query() { return new QueryBuilder( $this, $this->getQueryGrammar...DatabaseManager代理的数据库连接对象了, 所以最开始执行的代码 DB::table('users')->get()经过我们上面讲的历程,最终是由Connection来完成执行的,table方法返回了一个QueryBuilder...对象,这个对象里定义里那些我们经常用到的 where, get, first等方法, 它会根据调用的方法生成对应的SQL语句,最后通过Connection对象执行来获得最终的结果。

    1.7K30

    3分钟短文:Laravel 使用DB门面操作原生SQL

    引言 我们推荐使用laravel的eloquent orm 模型操作数据库表, 因为特性更为丰富,组装更为灵活,在编程层面操作数据的来来去去非常直观。...先说查询语句, 如果在数据库优化上做的比较好的一些SQL固定写法,可以使用原生方法固化下来。...扩展一下,带有查询条件的SQL原生语句, 为了防止SQL注入,使用参数绑定的方式: $usersOfType = DB::select('select * from users where type =..., [1]); 写在最后 本文通过对laravel DB门面的增删改查用法,向大家展示了基本的参数绑定的用法。...一般我们不推荐使用原生SQL语句操作数据库,提倡大家把数据库操作集中到模型层, 充分利用eloquent orm的性能。

    2.8K20

    Laravel拼装SQL子查询的最佳实现

    学习时间 对于数据库DBA可能更习惯从SQL的角度出发,从SQL现有的语言结构和功能上解决问题。...写多了容易无解,直接上SQL: ? 大家注意那个 IN 子句,其实是一个查询结果集,从另个表返回的。 写SQL真的很伤神,不如用框架自带的orm,操作起来非常人性化,拼装也很简单。...那就抛出一个问题,Laravel如何实现上述的子查询? 对Laravel来说,简直不要太简单,你只要在写whereIn的时候,将数组使用闭包返回就可以了。...写在最后 本文通过一个SQL语句查询在Laravel中的实现方式,解释了laravel在拼装SQL查询时的自由度,使用起来非常灵活。...对于固定的查询方式,或者经过优化的SQL语句,你大可直接发送给Laravel直接运行以便提高效率。

    4.7K10

    3分钟短文 | Laravel 自定义 SQL 查询参数绑定

    引言 laravel使用模型进行数据库操作时,并不是所有的字段或者关联关系 都能满足查询需求,有时候会有一些MySQL的函数计算等功能放在数据库 层面执行。 本文说一说自定义的参数绑定办法。...最重要就是 setBindings 方法了,传送的是前面自定义SQL语句的位置参数。只需一一对应上就可以了。...如果大家经常使用laravel的调试功能的话,应该会注意到,这种问号的写法是laravel本身封装SQL语句用的。...))*sin(radians(lat)))) AS distance SQL; 首先拼装好SQL语句的字段,然后使用laravel模型的方法: $property = Property::selectRaw...lng, $lat])->having('distance', 'orderBy('distance')->take(20)->get(); 写在最后 本文通过三种方式实现了laravel

    2.5K40
    领券