在上一篇教程中,我们通过查询构建器实现了简单的增删改查操作,而日常开发中,往往会涉及到一些更复杂的查询语句,比如连接查询、子查询、排序、分页、聚合查询等等,这一篇教程我们将围绕这些内容展开探讨。...你一定有过这样的经历,从数据库获取指定查询结果后,以主键 ID 值为键,以某个字段值为值构建关联数组,以前,你可能不得不遍历查询结果构建数组才能解决这样的问题,在 Laravel 中,我们只需在查询构建器上调用...null查询 NULL 查询就是判断某个字段是否为空的查询,Laravel 查询构建器为我们提供了 whereNull 方法用于实现该查询: DB::table('users')->whereNull(...,普通的 WHERE 查询也可以使用子查询,对应的方法是 whereSub,但是子查询的效率不如连接查询高,所以我们下面来探讨连接查询在查询构建器中的使用。...分页 日常开发中,另一个常见的查询场景就是分页查询了,在查询构建器中提供了两种方式来进行分页查询。
Laravel 数据库功能的核心就是提供流式接口与数据库进行交互的查询构建器(Query Builder),支持 MySQL、Postgres、SQLite 和 SQL Server 等常见的数据库管理系统...DB 门面提供的方法执行原生的 SQL 语句,DB 门面既可以用于构建查询构建器方法链,也可以用于原生语句的执行。...使用查询构建器进行增删改查 接下来,我们开始介绍 Laravel 数据库功能的核心组件 —— 查询构建器(说是核心,是因为 Eloquent 模型的底层也是基于这个查询构建器),日常开发中,我们与数据库的交互基本都是直接或间接通过它来完成的...查询构建器也是基于 DB 门面的,只不过需要调用其提供的 table 方法构建一个基于指定数据表的查询构建器。...,无需手动设置参数绑定来规避 SQL 注入攻击,因为 Laravel 底层会帮助我们自动实现参数绑定,所以推荐使用查询构建器进行数据库操作。
查询构造器 什么是查询构造器?...其实,查询构造器就相当于我们将原始 SQL 的操作进行了一次封装而已。而且,在模型中,其实内部调用的也是这个 查询构造器 。也就是说,查询构造器是介于 模型 和 原始语句 操作中间的一层。...在 查询构造器 中,还有其它很多的链式函数可以实现非常复杂的数据库操作,大家可以自己去研究一下。...我们又发现了一个设计模式在 Laravel 框架中的应用,意外不意外,惊喜不惊喜! 连表查询 普通的连表查询的使用还是非常简单的,我也就不多说了,下面的代码中也有演示。...这篇文章中,我们又看到了 建造者模式 的应用,以及了解到了 链式调用 是如何实现的。而且更重要的是,我们也确认了 查询构造器 确实在底层还是使用的 原始SQL 的方式执行的。
GraphQL 是一种 API 查询语言,还是一种根据你为数据定义的类型系统执行查询的服务器端运行时。GraphQL 不依赖于任何指定的数据库或存储引擎,而是由你的代码和数据来作支持的。...graphql.org GraphQL 可以提升 API 调用的灵活性,我们可以像写数据库查询语句一样来请求 API 来获取所需要的数据,这对构建复杂的 API 查询来说非常有用。...安装 Laravel 使用下面命令安装最新版本的 Laravel : # 在命令行中执行 composer global require "laravel/installer" laravel new...创建查询和定义 GraphQL 的类型 GraphQL 中的查询与 Restful API 中的末端路径查询是一样的,查询只是用于获取数据,以及创建、更新、删除操作。...GraphQL 中的 类型 用于定义查询中每个字段的类型定义,类型会帮助我们格式化查询结果中的有格式的字段,例如布尔类型,字符串类型,浮点类型,整数类型等等,以及我们的自定义类型。
获取结果 从表中检索所有行 $articles = DB::table('article')->get(); foreach ($articles as $article...$region->name.PHP_EOL; } //您可以通过从闭包中返回 false 来停止处理其余的块 //return false...->orWhere('title', '=', 'Admin'); }) ->get(); #子查询...查询结果默认根据数据表的 created_at 字段进行排序 。...'>', 100)->dd(); DB::table('users')->where('votes', '>', 100)->dump(); 参考 https://learnku.com/docs/laravel
1.Controller之Request Laravel中的请求使用的是symfony/http-foundation组件,请求里面放了$_GET,$_POST,$_COOKIE,$_FILES,$_SERVER...在student控制器里新增一个方法test6。...Laravel支持多种session后端驱动,并提供了统一的清楚的api。也内置了memcached、redis、数据库的后端驱动。默认使用了file的文件后端驱动。...Session的配置文件在config/session.php中。...Laravel中使用session有三种方式: HTTP中Request类的session()方法、session()辅助函数、session facade。
Laravel中的服务容器 我们已经了解了服务容器是个什么东西,也知道了依赖、依赖注入、控制反转以及最终的服务容器的概念和它们要解决的问题。...今天,我们就来一起学习一下 Laravel 中的服务容器是怎么使用的,大家一起来看看它是不是和我们上回学习到的服务容器是一样的。...使用 Laravel 中的服务容器 在 Laravel 中使用服务容器非常简单,我们首先还是定义那几个测试的类,不过这次我们把它们分开到不同的文件中存储。...下一篇文章中我们再看源码,不过 Laravel 中的源码可比我们自己定义的那个要复杂多了。然而,万变不离其宗,思想毕竟都是一致的。...官方的解释是 服务提供者是所有 Laravel 应用程序的引导中心。你的应用程序,以及通过服务器引导的 Laravel 核心服务都是通过服务提供者引导。
Redis 在 Laravel 中有两个角色,缓存和数据库 数据库 配置文件 config/database.php 作为数据库使用,有两个REDIS_CLIENT可选,默认是phpredis(php...cache')->client()->set('d',1); app('redis.connection')->set('e', 1); //没提示,和connection('default') 一样 Laravel...的 config/app.php 配置文件包含了 aliases 数组,该数组可用于定义通过框架注册的所有类别名。...方便起见,Laravel 提供了一份包含了所有 facade 的别名入口;不过,Redis 别名不能在这里使用,因为这与 phpredis 扩展提供的 Redis 类名冲突。...如果正在使用 Predis 客户端并确实想要用这个别名,你可以在 config/app.php 配置文件中取消对此别名的注释。
引言 鉴于上一章标题引起一些开发同学的巨大兴趣,本文我们接着此种行文方式继续我们的“Laravel宇宙”系列文章。...本文先不说模型,说说直接的查询构造器,说说怎么把数据筛选出来,这用的应该是最多的了。 代码时间 说起柔顺,你想起来什么?是撸代码,没错,就是它。...为了演示查询构造器的功能用法,我们直接使用 DB 门面创建 QueryBuilder 对象。...我们引入查询构造器,引入模型,就是为了摆脱繁杂的SQL语法,这里又传入原生语句,不提倡!...写在最后 本文轻描淡写地讲解了laravel中的查询构造器,讲了一个比较复杂的OR查询,因为使用闭包组装WHERE约束条件,所以会有些难以理解, 不过对比打印生成的SQL语句后,大家应该会豁然开朗!
当使用laravel的日志类记录信息的时候 Log::info("xxxx") 发现Log类里并没有定义info 静态方法,但是仍然可以调通 原因就是__callStatic魔术方法,当静态方法不存在的时候...简单的测试用例 <?
Laravel的config下一般存放配置信息,可以通过config('key')方法获取指定的数据。 设置值可通过「点」式语法读取,其中包含要访问的文件名以及选项名称。...现在想读取\config\app.PHP文件的url,文件中数据为: 'url' => 'http://localhost', 获取方法: config('app.url') 如果找不到app.url,
在Effective Java中, 有对构建器的讲解, 看了 java中Builder构建器的理解 之后, 了解了Builder不光只注重了代码优雅, 还注重了对象状态一致性, 以及对后续线程安全的考虑...tom.setName("Jerry"); } } 下面总结摘自 java中Builder构建器的理解 所以说Builder构建器的真正意义并不是代码优美 Effective...Java中写到:遗憾的是,javaBeans模式自身有着很严重的缺点。...因为构造过程被分到了几个调用中,在构建过程中JavaBeans可能处于不一致的状态。类无法仅仅通过检验构造器参数的有效性来保证一致性。...Builder构建器:既能保证构建时的灵活性,还能保证创建对象的一次性。这就需要一个内部类来存储预设置的属性,在调用bulid()方法的时候一次性构建出来所需要的对象。
前言 ArcGIS Pro的模型构建器在功能上相较于大致没有什么改动,主要是界面上变得相对漂亮,流程中使用了一些半透明的效果,相较于arcmap中的模型构建器,可以说是颜值进化很大了。...接下来我会以教程案例一中的案例来构建模型,没看过的同学可以去看看教程案例一 实战 首先我们来看一下演示效果,怎么样,是不是很方便 ?...先建立一个模型 对于模型构建器我一直认为,他就是类似搭积木的玩具,只要你会用使用GIS实现这个需求,那么你就可以构建出这样一个模型,很简单,但却很方便 ? 首先要建立一个存放数据的GDB数据库吧 ?...选择合适的土地利用 通过查询属性表得知,usecode字段,开头为11,12的土地类型是耕地和园地 ? 添加选择工具,选择出合适的地区 ? 创建tin ?...坡度分析 并对高程栅格和坡度栅格进行重分类,按照要求山选出所需要的地区,勾选忽略nodata ? 添加栅格转面工具,将符合选址条件的地区由栅格转为矢量 ? 对水源地图层water建立缓冲区 ?
最初 Chromium Webview 代码是位于 AOSP 源码树中,和 AOSP 源码一起构建。...AOSP 中不再包含原来的 Browser 代码,以前的浏览器是一个全功能浏览器,长这样: 而现在的 AOSP 中只包含了一个 WebView Shell,简陋之极: Webview Shell 的代码...要在 chromium 中编译出来,构建目标选择 system_webview_apk,生成的输出文件称为 SystemWebView.apk。...platform=Android 查询当前的稳定版和测试版版本号。但需要注意的是,Chromium 采用滚动发布的模式,版本更新非常频繁,开发产品,还是稳字当头,没有必要追求最新版本。...关于 Android 10 中的浏览器构建就先谈到这儿,当然最主要的工作还是从 Chromium 源码构建 WebView,以及对 Chromium 的定制,这个话题很大,有需要再说说。
前言 ArcGIS Pro的模型构建器在功能上相较于大致没有什么改动,主要是界面上变得相对漂亮,流程中使用了一些半透明的效果,相较于arcmap中的模型构建器,可以说是颜值进化很大了。...接下来我会以教程案例一中的案例来构建模型,没看过的同学可以去看看教程案例一 实战 首先我们来看一下演示效果,怎么样,是不是很方便 先建立一个模型 对于模型构建器我一直认为,他就是类似搭积木的玩具,只要你会用使用...GIS实现这个需求,那么你就可以构建出这样一个模型,很简单,但却很方便 首先要建立一个存放数据的GDB数据库吧 选择合适的土地利用 通过查询属性表得知,usecode字段,开头为11,12的土地类型是耕地和园地...添加选择工具,选择出合适的地区 创建tin 坡度分析 并对高程栅格和坡度栅格进行重分类,按照要求山选出所需要的地区,勾选忽略nodata 添加栅格转面工具,将符合选址条件的地区由栅格转为矢量...对水源地图层water建立缓冲区 水系缓冲区,坡度,高程,土里利用图层相交 筛选出符合条件的地区面积为50-80亩(注:1亩=666.67平方米)
什么是Swoole 直接套用Swoole官网的介绍:PHP的异步、并行、高性能网络通信引擎,使用纯C语言编写,提供了PHP语言的异步多线程服务器,异步TCP/UDP网络客户端,异步MySQL,异步Redis...,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。...Swoole内置了Http/WebSocket服务器端/客户端、Http2.0服务器端。 Swoole官网的文档不够丰富啊,这比较头疼,但大部分的问题都解释了。...如果你Swoole业务代码是写在一个叫server.php的文件中,那么在命令行下输入php server.php开启。...start 现在你就可以测试你的数据库查询了。
WordPress 中的jQuery 库问题曾经困扰了我一段时间。...如果仅仅加载WordPress 自带的jQuery 库,在使用一些jQuery 插件的时候明明是代码没有错误,但就是不起作用,该有的效果不能实现;但加载了原版的jQuery 库却又可以了,这样一来却同时加载了两个...$ 代替jQuery 的写法不能识别,一些功能不起作用的原因正是由此而来。...如何解决这个问题,网络上有以下解决方案: 方案一:将相关js代码中的$ 手动改为 jQuery。...接下来就是改用官方或者第三方的jQuery 库,请直接参考: 《为你的WordPress 选择最佳的第三方jQuery 库》 我的话是两个都用上。
mysql中查询优化器的操作 1、MySQL使用基于成本的优化器,它将试图预测查询使用某种执行计划的成本,并从中选出成本最低的优化器。...2、查询优化器需要从存储引擎获得相应的统计数据,以生成查询的执行计划。...存储引擎为优化器提供了相应的统计信息,包括:一个表或索引有多少页、每个表的每个索引的基数是多少、数据行和索引长度、索引的分布信息等等。优化器基于这些信息来选择实施计划。...NULL possible_keys: NULL key: NULL key_len: NULL ref: NULL rows: NULL Extra: Impossible WHERE 以上就是mysql中查询优化器的操作
Laravel 框架中提供了很方便快捷的面向对象风格的电子邮件相关功能,可以通过 Markdown 语法、Blade 模板引擎来制作邮件模板,然后通过扩展 Mailable 类来配置邮件相关的属性。...尽管这是开发中非常普遍的应用场景,但在以往的版本中,想把 Mailable 扩展类与模板结合渲染到浏览器中查看却并不是一件非常便捷的事情。...从 Laravel 5.5 版本开始,这个问题得到了改变,Mailable 类实现了 Renderable 接口(Contract),这样我们就能够通过一个url直接在浏览器中查看最终生成的电子邮件。...,由于它实现了 Renderable 接口,就可以直接显示在浏览器中。...这就是我们的电子邮件最终将呈现在用户邮箱中的样子。开发过程中只要这样验证即可,在最终发布之前,所有的邮件类和邮件模板,可以在真实的邮件客户端中,或者通过电子邮件专用的测试工具进行一次性地测试验证即可。
领取专属 10元无门槛券
手把手带您无忧上云