Laravel 现在提供一套围绕 Guzzle HTTP 客户端](http://docs.guzzlephp.org/en/stable/) 构建的精简且高效的 API,允许你快速向其它 web 应用发起...你可能对 Laravel 已有的 Illuminate\Support\Str 这个类比较熟悉,它提供了各种有用的字符串操作函数。...基于这些函数, Laravel 7 现在提供了一个更加面向对象的、更加流畅的字符串操作库。你可以使用 Str::of 方法创建一个 Illuminate\Support\Stringable 对象。...有时候需要在查询执行过程中对特定属性进行类型转换,例如需要从数据库表中获取数据的时候。...(); 在该查询获取到的结果集中,last_posted_at 属性将会是一个字符串。
{task})来告知路由解析器需要从 Eloquent 记录中根据给定的资源 ID 去查询模型实例,并将查询结果作为参数传入而不是资源 ID。...{task},然后默认以参数值作为资源 ID 在底层通过 Eloquent 查询获取对应模型实例,并将结果传递到闭包函数或控制器方法中。...,路由解析器都会从请求 URL 中解析出模型 ID ,然后从对应模型类 Task 中获取相应的模型实例并传递给闭包函数或控制器方法: Route::get('task/model/{task_model...由于在正式开发中,出于性能的考虑通常会对模型数据进行缓存,此外在很多情况下,需要关联查询才能得到我们需要的结果,所以并不建议过多使用这种路由模型绑定。...cache(运行此命令之前先要清理之前的缓存),即只在生产环境中使用路由缓存,本地开发环境路由经常变动,且没有性能方面的考虑,无需缓存。
这个 query 的 where 条件是什么意思?就是我们上面这条 SQL 语句的查询条件。它就是去查询 db_sex 表里面的数据,然后把获得的结果对象返回回来。至于这个 ?...gender() 方法获得返回的结果,也就是获取上面的 BelongsTo() 对象。...然后来到最后的 tap() 中,tap() 是一个 Laravel 框架中定义的全局函数,和 env() 函数在一起的,它的作用是将第一个参数当作第二个参数的参数传递给第二参数,并执行第二个参数后,将第一个参数再返回回来...在这段代码中,就是先调用 BelongsTo 对象的 getResults() 方法,获得关联的真正的 DbSex 这个 Model 对象,然后通过回调函数中的 setRelation() 绑定到 laravel...最后 tap() 函数还是会把之前传递进行去的第一个参数的值,也就是最终的那个 DbSex 对象再一路返回到 __get() 中,这样,就完成了整个链条的调用。
本文同步至个人博客 需要掌握的 Laravel Eloquent 搜索技术 ,转载请注明出处。 当我们的应用程序访问较少时(例如在项目初期阶段),直接进行项目编码就可以解决大多数问题。...本文将带领大家学习 MySQL 和 Eloquent 在搜索模块中设计的相关技术。 基本的 Eloquent Where 查询 作为首个要讲解的搜索功能,我们先不涉及新知识点。...这就是 whereRaw 的工作原理。 接下来将焦点集中到真正的关键处理:我们通过 MySQL 的 lower() 函数将待查询的 JSON 数据等数据转换成小写字符,实现 不区分大小写 的查询操作。...5.6.8 以上的 Laravel 版本,可以查看 Laravel changelog 执行 sound like 操作,会进行一个发音相似性的算法,然后获取结果集。...但是这并不是我们需要关注的,我们仅需将待查询的字符串传给 where 语句即可。返回的结果集即会包含完全匹配的数据,也会包含发音近似的数据。 总结 Laravel 为我们提供了简单实用的查询功能。
本文将带领大家学习 MySQL 和 Eloquent 在搜索模块中设计的相关技术。 基本的 Eloquent Where 查询 作为首个要讲解的搜索功能,我们先不涉及新知识点。.../ 获取包含 foo 的文章 $result = Post::where('title', 'like', '%{$keyword}%')->get(); 我们可以看到 Eloquent 的模糊查询功能十分灵活...这就是 whereRaw 的工作原理。 接下来将焦点集中到真正的关键处理:我们通过 MySQL 的 lower() 函数将待查询的 JSON 数据等数据转换成小写字符,实现 不区分大小写 的查询操作。...5.6.8 以上的 Laravel 版本,可以查看 Laravel changelog 执行 sound like 操作,会进行一个发音相似性的算法,然后获取结果集。...但是这并不是我们需要关注的,我们仅需将待查询的字符串传给 where 语句即可。返回的结果集即会包含完全匹配的数据,也会包含发音近似的数据。 总结 Laravel 为我们提供了简单实用的查询功能。
而另外一个 map() 函数就不用多说了,之前我们说过,Laravel 的 PDO 在默认查询构造器的情况下,走的是 PDO::FETCH_OBJ ,获得的集合结果中的每个数据都是一个 stdClass...对象,而在 Model 下,走的则是 PDO::FETCH_CLASS ,也就是会和我们指定的模型类关联上,获得的结果都是一个 App\Models\MTest Object 对象。...在所有模型都要继承的 laravel/framework/src/Illuminate/Database/Eloquent/Model.php 类中,我们很快就能发现一个 query() 静态方法。...别急,get() 、find() 不都是在 查询构造器 中的方法嘛。我们来看看 Model 中的 __call() 这个方法。...参考文档: https://learnku.com/docs/laravel/8.x/eloquent/9406
引言 本期继续我们的laravel学习,主要说一说laravel使用eloquent orm 模型 读取数据库条目的几个常用方法。 ?...所以我们推荐使用where语句进行数据库SQL操作,将合适的结果集返回,这样精简了数据库负载, 再者,使用集合的操作方法,对结果集进行进一步的格式化,效率会高的多。...如果返回的是多个条目,就不能用这些方法了: $vipContacts = Contact::where('vip', true)->get(); 有一个标准的方法 get,就是返回一个 eloquent...如果你的数据库条目固定, 且是少量数据,那么直接用 $contacts = Contact::all(); 把记录全部拿出来就好了。...顺带再说一下聚合函数,使用关系型数据库很大的因素就是其拉取关系型数据很高效, 因此也内置了很多聚合函数用于数据聚合操作。
本系列教程使用 Laravel 5.0 版本,5.1 版本去掉了本系列教程主要讲解的元素(Auth 系统),不建议使用 5.1 来学习。...Laravel 已经为我们准备好了 Auth 部分的 migration,运行以下命令执行数据库迁移操作: php artisan migrate 得到的结果如下: 如果你运行命令报错,请检查数据库连接设置...模型 Models 接下来我们将接触Laravel最为强大的部分,Eloquent ORM,真正提高生产力的地方,借用库克的一句话:鹅妹子英!...Eloquent 提供的 Model 类 `Illuminate\Database\Eloquent\Model`,且都在 `\App` 命名空间下。...如果你想深入地了解 Eloquent,可以阅读系列文章:深入理解 Laravel Eloquent(一)——基本概念及用法 ---- 接下来进行 Article 和 Page 类对应的 articles
学习主题 该demo主要涉及如下几个知识点: 创建数据库并迁移数据表 创建表单,学习Laravel的blade模板引擎 创建名为Link的模型Model 保存数据进入数据库 从数据库中获得...Mapping)为Eloquent ORM,其实就是Model层,来管理数据库中的数据表且一一对应关系。...Eloquent比较好用在于它提供了很多Feature功能模块,这些模块提供了许多面向对象的方法便于使用,这样就不用写SQL语句了,且代码看起来也很舒服。。...这里注意下:如果不写table变量,laravel会自动根据model名字复数来找数据表,如这个model名字是link,那就找links表。...自带的验证规则,'url'也是laravel自带的URL验证规则,就是格式得符合URL格式,'|'表示且的意思。
Laravel 提供了一些超赞的组件,在我看来,它是目前所有 Web 框架中提供组件支持最好的一个。...20 多行精简到了 3 行,代码干净整洁功能清晰任何人都可以立马理解。...又一个示例 现在让我们看下第二个示例,假设我们一个用户列表,我们需要基于角色(role)过滤出来,然后进一步如果他们的注册时间为 5 年或以上且 last name 以字母 A-M 开始的仅获取第一个用户...如果你计划让它们可以在 Eloquent 集合上使用,你需要在此场景下做相应的代码处理才行。...需要注意的是,通过使用 Collection 类,您不仅可以获得一个方法库来简化编程工作,还可以选择一种从根本上改善代码的方法。
基于关联查询过滤模型实例 有结果过滤 有的时候,可能需要根据关联查询的结果来过滤查询结果,比如我们想要获取所有发布过文章的用户,可以这么做: $users = User::has('posts')->get...whereHas/orWhereHas 方法基于闭包函数定义查询条件,比如我们想要过滤发布文章标题中包含「Laravel学院」的所有用户: $users = User::whereHas('posts...('content', 'like', 'Laravel学院%'); })->get(); 无结果过滤 与 has/orHas 方法相对的,还有一对 doesntHave/orDoesntHave 方法...很显然,它们用于过滤不包含对应关联结果的模型实例。...统计关联模型 我们还可以通过 Eloquent 提供的 withCount 方法在不加载关联模型的情况下统计关联结果的数量。
通过 Laravel,开发者可以专注于业务逻辑,而无需过多关注底层细节。为什么使用 Laravel?优雅简洁的语法:Laravel 的语法简洁且易于理解,极大地提高了开发效率。...强大的工具和功能:如 Eloquent ORM、Blade 模板引擎、路由、认证和授权等。活跃的社区支持:Laravel 拥有一个庞大的社区,遇到问题时可以很容易找到解决方案。...基本路由示例Route::get('/', function () { return 'Hello, Laravel!'...中的 index 方法,并返回结果。...数据库与 Eloquent ORMLaravel 内置了一个强大的 ORM(对象关系映射)工具,叫做 Eloquent,它简化了数据库的操作。
引言 今天说一个细分的需求,在模型中,或者使用laravel提供的 Eloquent ORM 功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写? 本文通过几个例子,为大家梳理一下。...学习时间 假设有一个模型 Reservation,我们查询某个日期的预订条目数,首先构造日期字符串,使用内置函数: $now = date('Y-m-d'); 返回当前日期。...然后调用模型的 where 查询语句: $reservations = Reservation::where('reservation_from', $now)->get(); 上一条生成的SQL语句如下...to 在laravel中你可以使用 whereBetween 这个查询子句。...当然了,上面的方法是在SQL中直接进行筛选,如果查询结果限制的条目本身比较少,也能充分利用索引,所以不担心查询的速度,那么我们可以在查询完成后,在返回的 Eloquent Collection 集合上,
「ActiveRecord」是 ORM 的一种实现模式,Eloquent 则是 Laravel 版的「ActiveRecord」。...H:i:s,你还可以通过 $dateFormat 属性来自定义时间戳的格式,该属性值通过 PHP 的 date() 函数进行解析,所以原则上支持 date 函数支持的所有语法格式,比如将时间设置为 Unix...', '>', 0)->select('id', 'title', 'content')->get(); 对应查询结果如下: ?...(10)->limit(5)->get(); 对应的返回结果如下: ?...获取聚合结果 Eloquent 模型类同样支持 count、sum、avg、max、min 等聚合函数查询: $num = User::whereNotNull('email_verified_at')
作为Laravel开发者,你可能已经习惯使用Eloquent处理数据库数据,但在自定义数据处理、文件读写、任务调度等场景中,SPL往往比框架自带工具更轻量、更直接。...无需额外依赖在Laravel项目中,减少Composer依赖意味着更干净的composer.json。语义更清晰的代码SplQueue明确表示FIFO(先进先出),比直接用数组更容易让人理解代码意图。...性能敏感模块高并发、高频访问的核心逻辑。不建议在简单数组操作中滥用SPL,Laravel的Collection在多数场景下更友好。Laravel开发者如何使用SPL?...无需额外依赖在Laravel项目中,减少Composer依赖意味着更干净的composer.json。语义更清晰的代码SplQueue明确表示FIFO(先进先出),比直接用数组更容易让人理解代码意图。...性能敏感模块高并发、高频访问的核心逻辑。不建议在简单数组操作中滥用SPL,Laravel的Collection在多数场景下更友好。Laravel开发者如何使用SPL?
Eloquent ORM 本文会是一个Eloquent的使用教程,在此之前,我们先讲述下怎么搭建环境,完整的系列请查看orm 基础环境的搭建 记录下怎么用docker搭建laravel的环境 新建项目composer...create-project --prefer-dist laravel/laravel eloquent 添加laradock cd eloquent;git init;git submodule...,让phpstorm能自动提示laravel中的类。...通过Eloquent的Scheme Builder构建数据库 通过使用Schema Builder我们可以在设计数据库的时候,不写一行sql,通过Schema Builder,我们可以 creating...总结 本文主要是介绍了使用docker来构建laravel的开发环境,同时,我们也介绍了怎么说会用phpstorm来开发laravel,搭建好环境后,主要介绍了Eloquent的Schema Builder
做演示自然选择开箱即用的第二类,于是我挑了一个功能常见且简单的Cachet。...所以,这个检查形同虚设,用户输入的数组 0x03 Laravel代码审计 熟悉Laravel的同学对where()应该不陌生,简单介绍一下用法。...而且因为这个API接口是GET请求,所以无需用户权限,这是一个无限制的前台SQL注入。 Laravel的这个数组特性可以类比于6年前我第一次发现的ThinkPHP3系列SQL注入。...且Laravel不支持堆叠注入,那么要利用这个漏洞,就有两种方式: 通过UNION SELECT注入直接获取数据 通过BOOL盲注获取数据 UNION肯定是最理想的,但是这里无法使用,原因是用户的这个输入会经过两次字段数量不同的...再发送下面这个数据包来执行名为“ssti”的模板,获得结果: POST /api/v1/incidents HTTP/1.1 Host: localhost:8080 Accept-Encoding:
所以,软删除的概念,极为重要。 本文我们仍然不厌其烦地讲解软删除的功能。 物理删除 其实就是真实地把数据从数据库条目清除,laravel模型提供了开箱即用的方法。...软删除 在许多情况下,你不会真正想要从数据库中删除记录,而是用一种不再在应用程序中显示它们的方式对其进行注释。这就是所谓的软删除。...namespace App; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\SoftDeletes;...任何设置deleted_at为日期时间值的记录,都不会包含在任何查询结果中,因此看起来已经被删除了。...如果你在代码内要坚持查询全量数据,也包含软删除了的数据,那么代码这样写: $events = Event::withTrashed()->get(); 写在最后 本文我们有重温了laravel的模型软删除功能
EloquentModel, Eloquent是建立在 DB的查询构建器基础之上,对数据库进行了抽象的 ORM,功能十分丰富让我们可以避免写复杂的SQL语句,并用优雅的方式解决了数据表之间的关联关系。...Eloquent Model 的连接分析器(connection resolver),让model能够用db服务连接数据库。...ConnectionFacotry)获得数据库连接对象(Connection),然后数据库连接对象会进行具体的CRUD操作。...函数,生成普通的连接对象。...where, get, first等方法, 它会根据调用的方法生成对应的SQL语句,最后通过Connection对象执行来获得最终的结果。
继续介绍 Laravel Eloquent 的小技巧 11....下面的代码是不行的: $clients = Client::orderBy('full_name')->get(); //不行滴 当然解决方案也是非常简单。 我们需要在得到结果以后再对他们进行排序。...但是查询的返回都是一个 Collection 对象,Laravel 为集合提供了很多方便的操作方法,sortBy 就是其中一个,当然还可以用 filter 等集合操作) 12....- created_at) desc') ->get(); (本质上Eloquent就是对 DB 查询对象的一个封装,所以可以用在 DB 上的原始查询方法,都可以用在继承自 Eloquent 的...正确的方法稍微有些复杂,需要用到闭包函数作为子查询: $q->where(function ($query) { $query->where('gender', 'Male')