whereHas/orWhereHas 方法基于闭包函数定义查询条件,比如我们想要过滤发布文章标题中包含「Laravel学院」的所有用户: $users = User::whereHas('posts...: 如果你想进一步过滤出文章标题和评论都包含「Laravel学院」的用户,可以在上述闭包函数中通过查询构建器进一步指定: $users = User::whereHas('posts', function...whereHas 方法和 orWhereHas 方法相对的,也有 whereDoesntHave 和 orWhereDoesntHave 方法,使用方法一样,这里就不再赘述了。...: 这个功能用于不考虑性能的场景进行快速查询还是很方便的,但如果对性能有较高要求,则不推荐使用,毕竟是要执行多次查询才能逐个统计出来。...所以不管模型实例有多少个,关联结果只会查询一次,加上模型本身查询总共是两次查询,在列表查询时,大大减少了对数据库的连接查询次数,因而有更好的性能表现,推荐使用。
很多情况下会用到复合查询: ---- $query->orWhere('target_type','offline'); $query->where(function($query
查询小技巧 我们首先来介绍几个 Laravel 自带的语法糖,可以帮助我们快速获取期望的查询结果,提高编码效率。...有时候,我们想要获取的并不是一行或几行记录,而是某个字段的值,你当然你可以查询到一行记录后从结果对象中获取指定字段的值,但是 Laravel 为我们提供了更便捷的语法: $name = '学院君'; $...你一定有过这样的经历,从数据库获取指定查询结果后,以主键 ID 值为键,以某个字段值为值构建关联数组,以前,你可能不得不遍历查询结果构建数组才能解决这样的问题,在 Laravel 中,我们只需在查询构建器上调用...,普通的 WHERE 查询也可以使用子查询,对应的方法是 whereSub,但是子查询的效率不如连接查询高,所以我们下面来探讨连接查询在查询构建器中的使用。...查询构建器提供的原生查询支持请参考官方文档,里面说的比较详细,这里就不再赘述了;如果查询构建器提供的原生方法还不能满足你的需求,那只有使用 DB 门面进行彻底的原生查询操作了。
up前面玩了 DB 查询,但是laravel开发基本不怎么使用db方式查询,应该有更强大的 模型 Model 介绍 Laravel 的 Eloquent ORM 提供了一个漂亮、简洁的 ActiveRecord...laravel 的 Model 使用先进的 Eloquent ORM 但也有优缺点 优点是数据库的操作变的简单安全 缺点也明显数据库的操作变的缓慢笨重 Eloquent ORM 作为 laravel 中亮点...使用的是单数形式帕斯卡命名法 ,也就是首字母大写的驼峰命名法 比如 up之前创建的 test表 Model 命名就是 Test.php 但是呢, laravel 都能 用命令创建控制器生成表跟数据填充了...但是有点写法可能不太明白这种类名跟一个变量直接当参数传给方法的 function index(Test $testMdl) laravel 中大量使用了这种方法,百度了下才知道这个东西叫做 依赖注入 。...像 get 里面这一长串方法一样,我们在查询数据的时候经常会有略微复杂的查询把它们写成一个模型方法 比如说在 app/Models/Test.php 文件中写一个 getList 方法 <?
[Laravel] Laravel的基本HTTP路由 使用Laravel的基本路由,实现get请求响应,找到文件app/Http/routes.php 调用Route的静态方法get(),实现get响应...(),参数:路径,匿名函数 路径,大括号包裹参数名,不含$,例如:’/user/{id}’ 匿名函数,接收参数,例如:function($id){} [Laravel] Laraval的基本控制器 在app...,例如:Route::get("/index","Index\IndexController@index");, 注意命名空间部分,新建的控制器是在根命名空间下面,指定的时候添加自己新加的命名空间 [Laravel...] Laravel的基本视图 在目录resources/views/下面,创建index/index.php 在控制器中使用函数view()来调用模板,参数:文件路径(.分隔目录),数据 路由:routes.php...$id; }); /*使用控制器*/ Route::get("/index","Index\IndexController@index"); /* |--------------------------
其实就像我们上篇文章中学习过的使用原始 SQL 语句的方式来操作数据库一样,查询构造器这个东西就是在这个原始操作的基础上为我们封装了一系列的接口,能够让我们方便地来操作数据库。...当然,要使用哪种一般会是团队的选择,而且往往更多情况下是 查询构造器 和 模型 两个结合起来使用。 好了,话说回来,我们还是看看代码。...我们又发现了一个设计模式在 Laravel 框架中的应用,意外不意外,惊喜不惊喜! 连表查询 普通的连表查询的使用还是非常简单的,我也就不多说了,下面的代码中也有演示。...`sex` }); 代码中第一段的连表查询就是最普通的一个外键的查询,如果要实现多个外键连表的话,就需要使用第二种方法。...总结 关于 查询构造器 的其它使用在官方文档上都有,今天的文章就只是简单地介绍了一些常用的和独特的查询构造方式而已,毕竟我们的系列文章的主旨还是在分析源码上。
我们将那些需要在多处调用的查询条件编写过滤器,然后将调用查询代码的地方改为调用过滤器,调用过滤器比编写那些冗长而重复的查询方法更加便捷,可读性也更好。...接下来,我们就来演示如何在 Eloquent 模型类上使用「作用域」进行查询。...,不同场景需要不同的预置过滤器,这个时候就不能使用「全局作用域」了,要改用「局部作用域」,在不同场景应用不同的局部作用域来完成查询功能。...推荐使用这种方式来构建需要在多个场景调用的复杂 Eloquent 查询。 移除局部作用域很简单,不要在查询中指定对应的过滤器方法即可。...`deleted_at` is null 动态作用域的调用和移除方式和局部作用域一样。 本系列教程首发在Laravel学院(laravelacademy.org)
当使用laravel的日志类记录信息的时候 Log::info("xxxx") 发现Log类里并没有定义info 静态方法,但是仍然可以调通 原因就是__callStatic魔术方法,当静态方法不存在的时候...简单的测试用例 <?
包含两部分: 1、 laravel自身的token 2、第三方passport封装好的token 自带token passport的token
什么是Swoole 直接套用Swoole官网的介绍:PHP的异步、并行、高性能网络通信引擎,使用纯C语言编写,提供了PHP语言的异步多线程服务器,异步TCP/UDP网络客户端,异步MySQL,异步Redis...,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。...这是比较头疼的事情,因为Laravel框架可不是这样的运转的,那如何能与Laravel结合呢?没错,自定义一条Artisan Command,就这么简单。...强烈推荐在你的laravel项目中,使用 laravel-s 这个包. composer require "hhxsv5/laravel-s:~1.0" -vvv 然后,依赖 kuaiapp/db 这个包...start 现在你就可以测试你的数据库查询了。
setxxAttribute 在设置(sql: insert update) 的时候 会将$obj->xx = ‘value’的时候, 操作数据库之前 自动转化一下 getxxAttribute 在获取...xx属性的时候 $obj->xx 会转化 示例: //获取之前首字母大写 public function getFirstNameAttribute($value) {...return ucfirst($value); } //存入之前的改变 public function setFirstNameAttribute($value) {...$this->attributes['first_name'] = strtolower($value); } 定义一个访问器 定义一个修改器 注意:使用驼峰格式命名 https://laravel-china.org.../docs/laravel/5.6/eloquent-mutators/1406 参考链接 https://laravel.com/docs/5.5/eloquent-mutators#array-and-json-casting
最近,公司接了一个laravel的项目,可惜没有phper,于是开始学习laravel,现在的情况就是还没学会走路就要开始跑了,所以遇到坑会摔得很痛!...C:/php/ext/下去找openssl.dll文件 解决: 他开的是虚拟机,修改extension_dir = "./" 路径为绝对路径 报错: 原因:laravel为了防止跨站脚本攻击(CSRF)...如 ⑤遇到跨域问题(laravel跨域)) 运行命令 php artisan make:middleware EnableCrossRequestMiddleware 自动在app/Http/Middleware...\App\Http\Middleware\EnableCrossRequestMiddleware::class, ]; ⑥composer安装报错 报错:win7下使用命令行安装的...composer使用时莫名其妙报错 [JsonSchema\Exception\ResourceNotFoundException] file_get_contents(file://): failed
; }); #如果您打算在分块时更新检索到的记录,最好使用 chunkById 方法 DB::connection('mysql2')->table('...,最好使用 lazyById 或 lazyByIdDesc 方法。...->orWhere('title', '=', 'Admin'); }) ->get(); #子查询...查询结果默认根据数据表的 created_at 字段进行排序 。...'>', 100)->dd(); DB::table('users')->where('votes', '>', 100)->dump(); 参考 https://learnku.com/docs/laravel
为什么80%的码农都做不了架构师?>>> ?...Compare this with https://github.com/laravel/laravel/blob/master/app/Http/Kernel.php EDIT It seems
这一篇主要聊聊Laravel如何优雅的使用Swoole,其实只需简单3步就可以完成。...什么是Swoole 直接套用Swoole官网的介绍:PHP的异步、并行、高性能网络通信引擎,使用纯C语言编写,提供了PHP语言的异步多线程服务器,异步TCP/UDP网络客户端,异步MySQL,异步Redis...,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。...这是比较头疼的事情,因为Laravel框架可不是这样的运转的,那如何能与Laravel结合呢?没错,自定义一条Artisan Command,就这么简单。...,就可以把各种业务逻辑写进Laravel框架中,然后就可以使用Laravel提供的各种高效方便的功能了。
而我们的 Laravel 从入门到精通系列教程之旅也将从路由开始,在这篇真正意义上的开篇教程中,我们将学习如何定义路由,然后将其指向要执行的代码,并处理各种路由需求。...这就是一个最简单的 Laravel 路由定义,但是涵盖了一个 Web 框架的基本功能:处理请求,返回响应。...注:这里需要注意的是,我们并没有通过 echo 或 print 显示输出内容,而是通过 return 将其返回,Laravel 会通过内置的响应栈和中间件对返回内容进行处理。...你可以在视图文件中这么使用: 此外,Laravel 还允许你为每个路由命名,这样一来,不必显式引用路径 URL 就可以对路由进行引用,这样做的好处是你可以为一些复杂的路由路径定义一个简单的路由名称从而简化对路由的引用...,而使用关联数组的方式传递参数则没有这样的约束。
消息队列的主要特点是异步处理,主要目的是减少请求响应时间和解耦。所以主要的使用场景就是将比较耗时而且不需要即时(同步)返回结果的操作作为消息放入消息队列。...同时由于使用了消息队列,只要保证消息格式不变,消息的发送方和接收方并不需要彼此联系,也不需要受对方的影响,即解耦和。...=redis 使用redis驱动 REDIS_CLIENT=predis 使用predis 生成队列需要的数据表 有时候队列会执行失败,这张表用于存放失败信息 php artisan queue:failed-table...,需要注意 数据库的读写直接使用 DB 类,而不是使用 ORM 因为一般我们会在模型监听器中分发队列任务,此时,会形成一个死循环 通过 ORM 写数据库,触发 ORM 监听器 -> 分发队列任务 ->.../horizon:~1.0" 生成配置 php artisan vendor:publish --provider="Laravel\Horizon\HorizonServiceProvider" 接下来输入
Laravel 中使用 DingoAPI 安装laravel 这里以5.5版本为例 composer create-project laravel/laravel laravel-api --prefer-dist...和 API_DOMAIN : 前缀和子域名, 前缀或子域名是必须的,并且同时只有一个 API_NAME : API的名字只有在使用API Blueprint命令生成文档的时候才用到,这个名字作为默认名字以免生成文档时需要手动指定名字...DingoApi ,因此我们同样使用 DingoApi 的路由。...来进行测试 推荐使用 POSTMAN 调试工具, 网址中输入地址 http://laravel-api.test/api/test ,不出意外 应该会输出 hello world 字样 另外一种很常见的访问方式是通过...ok,以上就是 laravel 中初步安装 DingoApi ,并且配置的基础教程,更多使用请阅读 官方文档
Laravel 框架使用过程中的一些笔记。...线上部署 相关过程 LNMP 一键安装包 记 LNMP 一键安装后 Laravel 线上部署的坑 关键步骤 安装 composer Composer 官网 git 部署 安装 git,$ sudo apt...因而包括 Emoji 表情(Emoji 是一种特殊的 Unicode 编码)在内的非基本多文种平面的 Unicode 字符都无法使用 MySql 的 utf8 字符集存储。...这也应该就是 Laravel 5.4 改用 4 字节长度的 utf8mb4 字符编码的原因之一。...laravel-admin.org Demo: http://laravel-admin.org/demo/auth/login To Be Continued.
AWS_ENDPOINT'), #源站 ], 三、配置说明 AWS_BUCKET=test AWS_ENDPOINT=http://s3.amazonaws.com/ 注意:这里的endpoint...是不需要桶名字的,最终源站就是test.s3.amazonaws.com 四、使用案例 $bucketName = 'test'; $client = S3Client::factory