首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

通过 Laravel 查询构建器实现复杂的查询语句

你一定有过这样的经历,从数据库获取指定查询结果后,以主键 ID 值为键,以某个字段值为值构建关联数组,以前,你可能不得不遍历查询结果构建数组才能解决这样的问题,在 Laravel 中,我们只需在查询构建器上调用...使用该方法时,需要注意传递给 whereIn 的第二个参数不能是空数组,否则会报错。 同样,与之相对的,还有一个 whereNotIn 方法,表示与 whereIn 相反的查询条件。...'users') ->where('options->language', 'en') ->get(); 如果属性字段是个数组,还支持通过 whereJsonContains 方法对数组进行包含查询...,如 select * from posts p left join users u on p.user_id = u.id 右连接:与左连接相反,返回右表中的所有行,如果右表中的行在左表中没有匹配行,...注:当两张表有字段名相同的字段,并且这两个字段都包含在 select 方法指定的字段中,需要为其中一个字段取别名,否则会产生冲突,例如,假设 posts 表中也包含 name 字段,那么需要为 users.name

30.2K20

Laravel集合的简单理解

Laravel作为快捷并优雅的开发框架,是有他一定的道理所在的,并非因他的路由、DB、监听器等等。当你需要处理一组数组时,你可能就需要它帮助你快捷的解决实际问题。...打回原型 如果你想将集合转换为数据,其使用方法也非常的简单 微信图片_20191121144450.png 在不过与考虑性能的情况下,可以使用Laravel集合,毕竟它将帮你完成数组操作的百分之九十的工作...「键」,再将另一个数组或者集合的值作为「值」合并成一个集合 concat 将给定的数组或集合值附加到集合的末尾 contains 判断集合是否包含给定的项目 count 返回该集合内的项目总数 dd 打印集合的项目并结束脚本执行...diff 将集合与其它集合或纯 PHP 数组进行值的比较,然后返回原集合中存在而给定集合中不存在的值 each 迭代集合中的内容并将其传递到回调函数中 filter 使用给定的回调函数过滤集合的内容,...只留下那些通过给定真实测试的内容 first 返回集合中通过给定真实测试的第一个元素 groupBy 根据给定的键对集合内的项目进行分组 push 把给定值添加到集合的末尾 put 在集合内设置给定的键值对

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

    你可能需要了解下Laravel集合

    Laravel作为快捷并优雅的开发框架,是有他一定的道理所在的,并非因他的路由、DB、监听器等等。当你需要处理一组数组时,你可能就需要它帮助你快捷的解决实际问题。...,其使用方法也非常的简单 collect([1, 2, 3])->all(); ------> [1, 2, 3] 在不过与考虑性能的情况下,可以使用Laravel集合,毕竟它将帮你完成数组操作的百分之九十的工作...「键」,再将另一个数组或者集合的值作为「值」合并成一个集合 concat 将给定的数组或集合值附加到集合的末尾 contains 判断集合是否包含给定的项目 count 返回该集合内的项目总数 dd 打印集合的项目并结束脚本执行...diff 将集合与其它集合或纯 PHP 数组进行值的比较,然后返回原集合中存在而给定集合中不存在的值 each 迭代集合中的内容并将其传递到回调函数中 filter 使用给定的回调函数过滤集合的内容,...只留下那些通过给定真实测试的内容 first 返回集合中通过给定真实测试的第一个元素 groupBy 根据给定的键对集合内的项目进行分组 push 把给定值添加到集合的末尾 put 在集合内设置给定的键值对

    1.6K30

    Laravel框架关键技术解析

    通过__autoload或spl_autoload_register()方法进行自动加载 在Laravel架构中,通过函数spl_autoload_register实现类自动加载函数的注册,其中类的自动加载函数队列中包含了两个类的自动加载函数...:主要包含数据库迁移和数据库填充文件 public:为应用程序的入口目录,包含index.php,同时包含静态资源文件如CSS、JS、images等 resources:主要包含视图文件 storage...4.两个别名:一是容器核心别名,存在Application中的$aliases,另一个是外观别名,定义在app.php配置文件中,程序运行后存储在AliasLoader类实例的$aliases属性中 5...$deferredServices数组属性中,在使用服务容器进行解析时,如果发现这个服务在延时服务数组中,则会注册 D.响应的发送与程序终止 八、服务容器与服务提供者 A.服务容器 1.Laravel中服务容器相当于大脑...,对于方法也是一样 B.服务提供者 1.服务提供者中两个方法 register()用于服务绑定 boot()会在所有服务提供者注册完成后才被调用,这时可以在其中使用所有已经注册过的服务 2.注册服务提供者

    12K20

    PHP面试题集锦

    如laravel中的 _token 4、代码注入:代码注入是利用计算机漏洞通过处理无效数据造成的。问题出在,当你不小心执行任意代码,通常通过文件包含。写得很糟糕的代码可以允许一个远程文件包含并执行。...如许多PHP函数,如require可以包含URL或文件名。 防止: 过滤用户输入 在php.ini中设置禁用allow_url_fopen和allow_url_include。...)返回输入数组中某个单一列的值; ⑤array_combine()通过合并两个数组来创建一个新数组; ⑥array_reverse()以相反的顺序返回数组; ⑦array_unique()删除数组中的重复值...happen和happy两个字符串谁大,为什么? 在计算机中,常用编码有 ASCLL、 Unicode 等。...此函数显示关于一个或多个表达式的结构信息,包括表达式的类型与值。数组将递归展开值,通过缩进显示其结构。 php中传值与传引用的区别?

    6.9K20

    深入浅出 Laravel 的 Facade 外观系统

    外观组件配置 所有内置的外观组件的配置数据,同 Laravel 其它服务一样被定义在 config/app.php 文件中。...外观配置定义格式遵循 「别名」:「外观类」 的数据格式。当一个 HTTP 请求被接收时,将在处理请求阶段将这些「外观」组件加载到服务中。 接下来将深入分析外观服务的加载过程。...::class)->aliases(); 将两个配置数组合并后注入到 AliasLoader 完成 注册(register)。...外观服务的动态引入 我们知道 __autoload 魔术方法的作用是尝试加载未经定义的类,这样当我们使用一个未经引入的类时,则会自动的给我们引入这个类。...这样,当我们使用 App 类时实际上就是在使用 Illuminate\Support\Facades\App 类。 很完美么,我们的「狗蛋」终于与「世界上最好的语言」画上了等号。你就是我,我就是你。

    2.5K20

    【译】20个 Laravel Eloquent 小技巧(下)

    自定义属性排序 假设你有下面的一段代码: (设定了一个在返回对象时候的附加属性 ‘full_name’参见 tips5 模型属性: 时间戳, 附加属性(appends) 等) function getFullNameAttribute...(一个是 SQL 语句,自定义属性是数据库没有的字段当然不能直接用。...但是查询的返回都是一个 Collection 对象,Laravel 为集合提供了很多方便的操作方法,sortBy 就是其中一个,当然还可以用 filter 等集合操作) 12....Laravel 默认会给所有实体类配置时间戳,如果不需要一般是在模型中指定 $timestamps = false 18. update()方法的返回值是什么?...正确翻译 SQL 语句中的括号 到 Eloquent 的查询 假设在你的 SQL 查询中 包含了 and / or 这样的关键字,如下: ...

    2.8K10

    PHP 数组:索引数组与关联数组

    在静态语言(C、Java、Go)中,数组的定义通常是同一类型数据的连续序列,PHP 的数组从功能角度来说更加强大,可以包含任何数据类型,支持无限扩容,并且将传统数组和字典类型合二为一,在 PHP 中,传统的数组对应的是索引数组...增删改查 除了像上述代码那样通过指定初始值进行数组初始化,还可以初始化一个空数组,在 PHP 中,初始化空数组时不必指定数组大小,也不必指定数据类型: $fruits = []; 然后我们可以依次往数组中追加元素...精品课」这本书为例,我们可以将其所有属性都存放到一个数组里面: $book = [ 'Laravel精品课', '学院君', 2020, 99.0, false...]; 可以看到其中包含了所有的基本类型数据,此外,还支持数组、对象等更复杂的数据类型,如果我们试图通过 print_r($book) 打印该数组的话,输出如下: ?...2、关联数组 基本使用 PHP 没有字典(map/dict)这种数据类型,而是将其融入到数组中以关联数组的方式提供支持,与索引数组不同,关联数组通常需要显式指定数组元素的键,还是以「Laravel 精品课

    5.8K20

    10个技巧优化PHP程序Laravel 5框架

    使用专业缓存驱动器 config/cache.php 数据库请求优化 为数据集书写缓存逻辑 使用即时编译器(JIT),如:HHVM、OpCache 前端资源合并 Elixir 1....配置信息缓存 使用以下 Artisan 自带命令,把 config 文件夹里所有配置信息合并到一个文件里,减少运行时文件的载入数量: php artisan config:cache 上面命令会生成文件...你可以可以通过修改 config/compile.php 文件来添加要合并的类。 在 production 环境中,参数 --force 不需要指定,文件就会自动生成。...注意:此命令要运行在 php artisan config:cache 后,因为 optimize 命令是根据配置信息(如:config/app.php 文件的 providers 数组)来生成文件的。...数据库请求优化 数据关联模型读取时使用 延迟预加载 和 预加载 ; 使用 Laravel Debugbar 或者 Clockwork 留意每一个页面的总数据库请求数量; 这里的篇幅只写到与 Laravel

    5.4K20

    Laravel学习笔记之bootstrap源码解析

    Laravel在入口index.php时先加载Composer加载器:Laravel学习笔记之Composer自动加载,然后进行Application的实例化:Laravel学习笔记之IoC Container...$env属性的值了,开发代码中就可以App::environment()得到这个$env属性然后进行一些操作,可以看下environment()的源码,该方法有两个feature:如果不传入值则读取$env...这里如果对Application没有$env成员属性定义有疑惑,是因为PHP可以后期添加属性,如: class ClassField { } $class_field = new ClassField...的Log模块中已经内置了几个类型的LogHandler:Single,Daily,Syslog,Errorlog.根据config/app.php文件中'log'的配置选择其中一个handler,看下configureHandlers...这个过程主要使用了两个技术:一个是外观类的别名;一个是PHP的重载,可看这篇:Laravel学习笔记之PHP重载(overloading)。 6.

    3.9K00

    Laravel源码笔记(一)程序结构与生命周期

    database——数据库迁移及填充文件目录,这个在项目运维部署的时候很有用。 public——对外提供访问的地方,包含应用的入口文件index.php,同时包含js、css等静态资源。...在laravel中,服务容器以完全限定命名空间名称或用户自定义的别名(aliase)作为索引,将该类已有实例或实例的构造器存放到自身定义的instances和bingdings两个数组属性中。...Kernel内部定义还定义$middleware和$routeMiddleware两个中间件数组,前者是全局性的、对所有请求都会生效,而后者仅在请求命中相应路由时被调用。...then()中利用了php标准库函数——array_reduce(array, callback, initializer),把array数组传递过来的闭包元素进行打包,合并成了一个嵌套N(=数组长度)...)把业务接口函数放置在了反转数组顶部,这样在生成的函数栈调用次序就能与middlewares数组中定义时一致。

    2.5K31

    Laravel5.3之bootstrap源码解析

    Laravel在入口index.php时先加载Composer加载器:Laravel5.2之Composer自动加载,然后进行Application的实例化:Laravel5.3之IoC Container...env属性的值了,开发代码中就可以App::environment()得到这个env属性然后进行一些操作,可以看下environment()的源码,该方法有两个feature:如果不传入值则读取env值...的Log模块中已经内置了几个类型的LogHandler:Single,Daily,Syslog,Errorlog.根据config/app.php文件中'log'的配置选择其中一个handler,看下configureHandlers...异常处理 异常处理是十分重要的,Laravel中异常处理类\App\Exception\Handler中有一个方法report(),该方法可以用来向第三方服务(如Sentry)发送程序异常堆栈(以后在一起聊聊这个...这个过程主要使用了两个技术:一个是外观类的别名;一个是PHP的重载,可看这篇:Laravel5.2之PHP重载(overloading)。 6.

    7K51

    Laravel API教程:如何构建和测试RESTful API

    前言 本文原文:Laravel API Tutorial: How to Build and Test a RESTful API 这次一次来了两个没接触过的内容,一个与php的Laravel 有关,一个与...文章正文 随着移动开发与JavaScript框架的兴起,使用RESTful API为数据与客户端之间构建单一接口成为最佳选择。 Laravel 是一个 专注提高开发人员生产力的php开发框架。...请记住,URL不应包含动词,资源不一定是表中的行。要记住的另一件事是,您不必为每个资源实施每个操作。 创建你的项目 与所有现代PHP框架一样,我们需要Composer来安装和处理我们的依赖关系。...您也可以使用该$guarded 属性,以允许除属性外的所有属性。 Database Seeding Database Seeding是使用我们可以用来测试数据库的虚拟数据填充我们的数据库的过程。...这意味着当我们打到认证中间件时,它将当前用户保存在 TokenGuard 实例中,以避免再次触发数据库。

    20.4K20

    基于 Redis 消息队列实现 Laravel 事件监听及底层源码探究

    有了事件之后,还要创建一个监听这个事件的处理器: php artisan make:listener IncreasePostViews 编写处理器代码如下: 与监听器之间的映射关系,保证事件发生时可以通过监听器对其进行处理,需要在 EventServiceProvider 中维护一个监听数组配置: protected $listen = [...注册事件与对应的监听器处理逻辑 在 Laravel 应用启动过程中,会调用 App\Providers\EventServiceProvider 的 register 方法基于 listen 数组注册事件和监听器的映射关系...这两个类不是同一个类,也分别实现了不同接口。...null : $responses; } 在这个方法中,我们首先从参数中解析出事件名和载荷数据。 载荷数据在广播时会用到,我们后面介绍广播时再详细探讨它,这里先忽略。

    3.6K30

    JSON Web Token(JWT)教程:一个基于Laravel和AngularJS的例子

    当然,如果我们想避免使用JWE的额外开销,另一个选择是将敏感信息保留在我们的数据库中,并且在需要访问敏感数据时,使用我们的token进行额外的API调用。 为什么需要Web Tokens?...这可以在内存或数据库中完成。如果我们有一个分布式系统,我们必须确保我们使用一个不耦合到应用服务器的单独的会话存储。...'Tymon\JWTAuth\Providers\JWTAuthServiceProvider' 接下来,在 app/config/app.php 文件中的 aliases 数组中,我们添加 JWTAuth...当我们向一个API 服务器( server),如 api.jwt.dev/v1/restricted发出POST请求时,我们正在进行跨域请求,并且必须在后端启用CORS。...我们还定义了两个常量,其中包含我们对后端的HTTP请求的URL。 请求拦截器 AngularJS的$ http服务允许我们与后端通信并发出HTTP请求。

    30.6K10

    laravel 模型Eloquent ORM 查询

    每个数据库表都有一个对应的「模型」用来与该表交互。你可以通过模型查询数据表中的数据,以及在数据表中插入新记录。 在开始之前,请确保在 config/database.php 中配置数据库连接。...laravel 的 Model 使用先进的 Eloquent ORM 但也有优缺点 优点是数据库的操作变的简单安全 缺点也明显数据库的操作变的缓慢笨重 Eloquent ORM 作为 laravel 中亮点...Model { //根据model class获取表名 表名中包含_,用驼峰自动转换 public function getTable() { return...和使用了 DB 取出来的数据一样的是都是一个 Collection 集合,不一样的是 DB 取出来的是数组,Model 取出来的是一个类,需要一层一层的剥开点到 attributes 我们才能看到数据...像 get 里面这一长串方法一样,我们在查询数据的时候经常会有略微复杂的查询把它们写成一个模型方法 比如说在 app/Models/Test.php 文件中写一个 getList 方法 <?

    4.4K10

    CSS 预编译语言 Sass 快速入门教程

    变量 和 PHP 一样,Sass 的变量通过 $ 作为标识符,Sass 支持的数据结构包括数字、字符串、数组、颜色、布尔值、null、List、Map、函数引用(如果你不了解 Python 或 Java...这类编程语言,也不熟悉 Redis 中的数据结构,可以将 List 理解为 PHP 中未指定键名的索引数组,将 Map 理解为以字符串作为键名的关联数组): // 简单变量 $primary-color...#{$name} { #{$attr}-color: #44b336; } 有两个需要注意的地方,和一般编程语言数组或列表索引从 0 开始不同,Sass 中的 List 索引从 1 开始;另外,变量作为插入变量...4、结语 好了,通过以上语法的介绍相信你已经具备了编写 Sass 样式文件的能力,在基于 Laravel + Vue.js 驱动的项目中,我们通常会在两个地方编写样式代码,一个是 resources/sass...目录下独立的 .scss 文件,另一个是 Vue 组件中的 中,我们在属性中设置 lang="scss" 表示这里面是 Sass 代码,需要 Laravel

    7.2K41

    为什么 Laravel 这么优秀?

    因为我们已经完成了数据表中字段的定义、表与表的关系、以及最重要的一步:如何将数据及数据之间的关系写入数据库中,下面简单的来介绍下在 Laravel 是如何完成的。...另一个强大之处在于可以通过 Eloquent 抽象「模型与模型」之间的关系;举个例子,在下面的定义中我们描述了一个 Course 可以有多个 Student、一个 Teacher;以及一个 Student...ID 为 1 的课程及它所关联的教师及学生;这将产生 3 条 SQL操作,其中还包含了一条跨中间表(course_student)的查询,而这过程中我们不需要做任何操作,Laravel 会自动根据你...Laravel Route # 在 Laravel 中我们还可以非常方便的管理应用的路由;Laravel 的路由是集中式路由,所有的路由全部写在一两个文件中;Laravel 的 Route 给开发者暴露了一套简单的...Laravel 用一个数组保存你注册过的所有路由;在进行路由匹配时,Laravel 会用你当前请求的 pathinfo 来匹配已经注册的所有路由;当你的路由数量超级多时,最坏情况下你需要 O(n) 次才能找出匹配的路由

    26710
    领券