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

Laravel 应用构建 GraphQL API

代码示例:产品列表和用户列表的 API 例子 昨天我们学习了 Visual Code 搭建 Laravel 环境,现在我们来学习 Facebook 的 GraphQL 。...graphql.org GraphQL 可以提升 API 调用的灵活性,我们可以像写数据库查询语句一样来请求 API 来获取所需要的数据,这对构建复杂的 API 查询来说非常有用。...安装 Laravel 使用下面命令安装最新版本的 Laravel : # 命令行执行 composer global require "laravel/installer" laravel new...创建查询和定义 GraphQL 的类型 GraphQL 查询与 Restful API 的末端路径查询是一样的,查询只是用于获取数据,以及创建、更新、删除操作。...GraphQL 的 类型 用于定义查询每个字段的类型定义,类型会帮助我们格式化查询结果的有格式的字段,例如布尔类型,字符串类型,浮点类型,整数类型等等,以及我们的自定义类型。

3.4K20

Laravel 6 缓存数据库查询结果的方法

加快应用程序速度方面,缓存可能是最有效的。Laravel 预先安装了缓存驱动程序。因此你可以直接使用 Redis, Memcached 或者使用本地文件进行缓存操作。Laravel 附带了此功能。...如果此查询缓存为空,那么会去数据库获取数据,并且缓存它,以便下次可以从缓存获取。如果此查询存在于缓存,那么直接返回。...// 数据库访问,查询结果存储缓存 Article::latest()- get();// 未访问数据库,查询结果直接从缓存返回。...这很有用,因为我们可以缓存中标记查询,并在需要再通过 tag 使所需的缓存失效。 举一个简单的例子,如果我们要在更新一篇文章使文章列表不进行缓存,你可以像这样写。...Laravel 6 缓存数据库查询结果的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。

5.2K41
您找到你想要的搜索结果了吗?
是的
没有找到

Laravel5.6使用Swoole的协程数据库查询

高性能网络通信引擎,使用纯C语言编写,提供了PHP语言的异步多线程服务器,异步TCP/UDP网络客户端,异步MySQL,异步Redis,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询...如果你Swoole业务代码是写在一个叫server.php的文件,那么命令行下输入php server.php开启。...这是比较头疼的事情,因为Laravel框架可不是这样的运转的,那如何能与Laravel结合呢?没错,自定义一条Artisan Command,就这么简单。...强烈推荐在你的laravel项目中,使用 laravel-s 这个包. composer require "hhxsv5/laravel-s:~1.0" -vvv 然后,依赖 kuaiapp/db 这个包...start 现在你就可以测试你的数据库查询了。

3.7K20

laravel5.6框架操作数据curd写法(查询构建器)实例分析

本文实例讲述了laravel5.6框架操作数据curd写法(查询构建器)。分享给大家供大家参考,具体如下: laravel5.6 数据库操作-查询构建器 <?...limit($pageSize) - get(); //返回数据视图文件 return $this- view('index', ['result' = $result]); } } groupBy 对查询结果进行分组出现问题...当select和groupBy列表不一致时候会报错。...解决方法:找到config/database​.php mysql下面把’strict’ = true,改为false。[建议不要修改。写对正确操作语法。]...操作数据ORM 更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程

2.2K30

Laravel Eloquent 模型关联关系(下)

从性能上来说,渴求式加载更优,因为它会提前从数据库一次性查询所有关联数据,而懒惰式加载每次查询动态属性的时候才会去执行查询,会多次连接数据库,性能上差一些(数据库操作主要开销在数据库连接上,所以开发过程如果想优化性能...另外,如果访问的是模型实例上的 author() 方法,返回的不是用户实例了,而是一个关联关系实例,该实例注入了查询构建器,所以你可以在其基础上通过方法链的方式构建查询构建器进行更加复杂的查询,我们以一个一对多的查询为例...: 如果你想进一步过滤出文章标题和评论都包含「Laravel学院」的用户,可以在上述闭包函数通过查询构建器进一步指定: $users = User::whereHas('posts', function...注:实际开发为了提高查询性能,我们往往是 posts 表冗余提供一个 comments_count 字段,每新增一条评论,该字段值加 1,查询的时候直接取该字段即可,从而提高查询的性能。...所以不管模型实例有多少个,关联结果只会查询一次,加上模型本身查询总共是两次查询列表查询,大大减少了对数据库的连接查询次数,因而有更好的性能表现,推荐使用。

19.5K30

PHP-web框架Laravel-Eloquent ORM(三)

四、查询构建Laravel框架的Eloquent ORM提供了方便的查询构建器,用于构建复杂的查询语句。下面是一些常用的查询构建器方法。...总结通过上述文档和示例,我们可以看出Laravel框架的Eloquent ORM提供了便捷的对象关系映射功能,可以大大简化开发者的数据库操作。...它支持多种关联关系,包括一对一、一对多和多对多等,并且提供了方便的查询构建器,用于构建复杂的查询语句。...使用Eloquent ORM进行开发,需要注意以下几点:模型类名默认对应的表名是模型类名的复数形式,如User模型对应的表名是users,如果需要指定表名可以通过定义$table属性来实现。...查询构建器提供了丰富的方法来构建复杂的查询语句,可以根据具体需求进行使用。

1.5K41

为什么 Laravel 这么优秀?

接下来我们将尝试构建一个简易的课程系统,在这个系统中有教师(Teacher),学生(Student)和课程(Course),它们之间覆盖了简单的一对一、一对多、多对多等的关系,这在日常开发也很常见。...因为我们已经完成了数据表字段的定义、表与表的关系、以及最重要的一步:如何将数据及数据之间的关系写入数据库,下面简单的来介绍下在 Laravel 是如何完成的。...,我们就可以非常方便的通过 Laravel Eloquent 查询它们之间的数据关系。...Laravel 可以高效的使用 Eloquent ORM 实现各种查询;如上面的例子我们使用了 withCount 来查询课程的学生数量、用 with 加载课程对应的教师;还可以指定生成的 SQL...container 设置不同的值;如 CacheServiceProvider 会向容器中注册 Cache 对象,后续使用 Cache::get 就使用的是这里注册的 Cache 对象,注册阶段不应该向容器获取值

16510

laravel框架数据库操作、查询构建器、Eloquent ORM操作实例分析

本文实例讲述了laravel框架数据库操作、查询构建器、Eloquent ORM操作。...分享给大家供大家参考,具体如下: 1、连接数据库 laravel连接数据库的配置文件位于config/database.php,在其中connection字段包含laravel所支持的数据库的配置信息...Laravel将常用的数据库操作封装为接口函数提供给用户调用,从而使数据库操作更为便捷,这些接口就是查询构建器(query builder)。...而且通过PDO绑定的方式避免SQL注入攻击,使用查询构建不必考虑过滤用户输入。...使用create批量添加,需要在模板通过fillable指定可以赋值的字段,也可以guard指定不允许赋值的字段。

13.3K51

Laravel5+mycat 报错 “Packets out of order”

`deleted_at` is null order by `id` desc) at D:\\phpstudy_pro\\WWW\\projzqb1b\\vendor\\laravel\\framework...Packet size=85 at D:\\phpstudy_pro\\WWW\\projzqb1b\\vendor\\laravel\\framework\\src\\Illuminate\\Database...max_allowed_packet 参数 但是,发现不应该是这个问题,毕竟不使用 mycat 不会出现问题 继续查找发现,这个问题的原因很可能是数据库配置参数的 【预处理】问题 设置 database.php...的 options 的预处理可以解决报错 (但是查询出来的数据全部转为了字符串) 因为上述的变动,代码的判断,可能会出现问题,尤其是一些 数字类型的 === 比对 希望得到的结果:同时满足...PDO::ATTR_EMULATE_PREPARES => true 和结果集数据类型不被隐式转换 解决方案:Laravel取出mysql数据全部被转成string类型问题

4110

Laravel 数据库连接配置和读写分离

今天开始讲如何在 Laravel 操作数据库,Laravel 为我们提供了多种工具实现对数据库的增删改查,我们使用 Laravel 提供的这些数据库工具之前,首先要连接到数据库。...默认情况下,我们通过 Laravel 提供的数据库工具(DB 门面、查询构建器、Eloquent模型)连接数据库的时候,都没有显式指定连接,因为我们配置文件中指定了默认的连接 mysql。...connection 属性: protected $connection = 'mysql_old'; 这样,模型类上执行查询、插入等操作都会使用这个 mysql_old 数据库连接。...所以 Laravel 实现读写分离还是很方便的,我们只需要做好配置就好了,剩下的框架帮我们完成。...当然,和多个数据库连接类似,你也可以使用时显式进行指定,以查询构建器为例: DB::connection('read')->table('users')->where(...)

5.2K20

Laravel代码简洁之道和性能优化

经过一番调研之后发现了一个堪称神器的扩展:laravel-upsert 这个 Laravel 扩展为查询构建器和 Eloquent 添加了对 INSERT & UPDATE (UPSERT) 和 INSERT...如果互相喜欢,则添加双向联系人关系,插入之前校验是否存在,存在则更新type等字段,不存在则插入双向数据 我们通过这个场景能非常好的体会laravel-upsert的强大,不仅减少了代码量,也减少了sql... Laravel 5.5-5.7 ,这需要HasUpsertQueriestrait: class User extends Model { use \Staudenmeir\LaravelUpsert...Lumen 如果您使用 Lumen,则必须手动实例化查询构建器: $builder = new \Staudenmeir\LaravelUpsert\Query\Builder(app('db')->connection...->upsert(...); Eloquent ,所有版本的 LumenHasUpsertQueries都需要该特性。

5.7K20

Laravel中使用数据库事务以及捕获事务失败后的异常

Description Laravel要想在数据库事务运行一组操作,则可以 DB facade 中使用 transaction 方法。如果在事务的闭包内抛出异常,事务将会被自动还原。...你不需要担心使用 transaction 方法还需要亲自去手动还原或提交事务: DB::transaction(function () { DB::table('users')->update...Example 假设有要在数据库存储一个知识点,这个知识点同时属于两个不同的考点,也就是考点和知识点这两个数据是多对多的关系,那么要实现这种数据结构就需要三个表: 知识点表 wiki: 考点表 tag...: 考点知识点关联表 wiki_tag_rel 现在要开启事务新增Wiki数据,新增wiki成功后再把它关联到指定的考点上去 (laravel中使用查询构建器或者Eloquent ORM执行query...Database\QueryException; use App\Wiki; class TestController extends Controller { //用DB facade的事务方法控制 查询语句构建器的事务

1.3K40

Laravel Eloquent ORM 实现查询表中指定的字段

使用Laravel ORM的Model方法find, get, first方法获取数据对象返回的数据对象的attributes属性数组里会包含数据表中所有的字段对应的键值关系, 那么如何在ORM查询只返回数据表中指定字段的数据呢...由于ORM依赖了QueryBuilder来实现查询QueryBuilder的源码里通过查看get,first方法的实现可以到,他们都可以接收一个数组参数来指定要查询的字段: find方法的实现是...getQualifiedKeyName(), '=', $id); return $this- first($columns); } 由于Eloquent Query Builder是依赖查询构建器...columns = $columns; } return $this- processor- processSelect($this, $this- runSelect()); } 所以使用Laravel...以上这篇Laravel Eloquent ORM 实现查询表中指定的字段就是小编分享给大家的全部内容了,希望能给大家一个参考。

3.1K21

Laravel如何使用数据库事务及捕获事务失败后的异常详解

前言 如果大家Laravel要想在数据库事务运行一组操作,则可以 DB facade 中使用 transaction 方法。如果在事务的闭包内抛出异常,事务将会被自动还原。...你不需要担心使用 transaction 方法还需要亲自去手动还原或提交事务: DB::transaction(function () { DB::table('users')->update(['...示例介绍 假设有要在数据库存储一个知识点,这个知识点同时属于两个不同的考点,也就是考点和知识点这两个数据是多对多的关系,那么要实现这种数据结构就需要三个表: 知识点表 wiki: ---- id title...中使用查询构建器或者Eloquent ORM执行query,如果失败会返回 IlluminateDatabaseQueryException 异常) <?...IlluminateDatabaseQueryException; use AppWiki; class TestController extends Controller { //用DB facade的事务方法控制 查询语句构建器的事务

1.6K30

Laravel 使用查询构造器配合原生sql语句查询的例子

首先说一下本人使用的版本: 5.5 很多复杂查询, 往往需要原生语句进行查询, laravel , 我们可以这样使用原生查询 $user = DB::select('select * from..., [1]) 查询构建器 https://laravel-china.org/docs/laravel/5.5/queries#where-clauses $sql = '(FROM table_name1...res = $DB::table(DB::raw($sql))- where([["id"= 1]])- paginate(10); 在这里里面$sql 充当了 视图表(临时表), 可以是更为复杂的联合查询...; 这样我们可以使用 “where“,”paginate ” 等构建器; 需要注意的是: sql 字符串是用 括号 ‘()’ 括起来的, 不然会出错; 以上这篇Laravel 使用查询构造器配合原生sql...语句查询的例子就是小编分享给大家的全部内容了,希望能给大家一个参考。

3.1K41
领券