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

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

经过一番调研之后发现了一个堪称神器的扩展:laravel-upsert 这个 Laravel 扩展为查询构建器和 Eloquent 添加了对 INSERT & UPDATE (UPSERT) 和 INSERT...IGNORE 的支持 先简单说明一下业务场景: 首先结构设计是:互相喜欢和添加联系人都是双向关系,即入库A B,B A这样成对的双向数据 触发互相喜欢,插入2条双向数据,插入之前校验是否存在,存在不重复添加...如果互相喜欢,则添加双向联系人关系,插入之前校验是否存在,存在则更新type等字段,不存在则插入双向数据 我们通过这个场景能非常好的体会laravel-upsert的强大,不仅减少了代码量,也减少了sql...Lumen 如果您使用 Lumen,则必须手动实例化查询构建器: $builder = new \Staudenmeir\LaravelUpsert\Query\Builder(app('db')->connection...LaravelUpsert\Eloquent\HasUpsertQueries; 因为我们数据库的时间是int类型,不是laravel默认的时间格式,并且我们的插入时间和更新时间也不是laravel默认的字段

5.7K20

Love beautiful code? We do too.

PHP框架 Laravel是一个有着美好前景的年轻框架,它的社区充满着活力,同时提供了完整清晰的文档,而且为快速、安全地开发现代应用提供了必要的功能。...Laravel基于MVC架构,可以满足诸如事件处理、用户身份验证等各种需求,同时通过包管理实现模块化和可扩展的代码,并且对数据库管理有着健壮的支持。...微服务&API Lumen是一个由Laravel衍生的专注于性能的微框架。使用Lumen提供的高性能API你可以更加简单快速地开发微型项目。...Lumen使用最小的配置集成了Laravel的所有重要特性,你可以通过将代码复制到Laravel项目来实现框架的完整迁移。 <?...包含了一个数据库处理层,其中的对象关系映射被称作Eloquent

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

lumen搭建php微服务

与写入新数据相比,我们读取现有数据的倾向要大得多。因此,我们可能希望在只有几个写入服务的同时启动十二个读取服务。我们可能还想在写服务之前添加一个消息队列缓冲区,以处理峰值负载。...Lumen 它是一个精简的laravel框架,舍弃了laravel中许多繁重的功能,它可以高效率地对外提供api方法。...Lumen包含的特性 缓存 Command Scheduler 控制器 Eloquent ORM 错误处理 数据库抽象 依赖注入 日志 队列任务 总结 其实简单来讲,微服务就是一个个api接口,只不过这些...api接口不是由一个整体服务来提供,它是由一个个模块来提供,我们可以通过lumen来开发部署多个模块,每个模块单独部署,这就是我们所说的微服务。

50110

Laravel 7发行说明

版本化方案 Laravel及官方发布的包皆遵循 语义版本化。主要框架版本每六个月发布一次 (~2月和~8月),次要和补丁版本可能每周发布一次。次要版本和补丁 决不 包含非兼容性更改。...对于包括 Lumen 在内的所有其他版本,只有最新版本才会修复错误。此外,请查阅 Laravel 支持的 数据库版本。..., 第一方 CORS 支持, 路由模型绑定作用域改进, 存根自定义, 数据库队列改进, 多邮箱驱动, 查询时间强制转换(casts),新的 artisan test 命令,以及各种其他错误修复和可用性改进...get 方法负责将从数据库中获取的原始数据转换成对应的类型, set 方法则是将数据转换成对应的数据库类型以便存入数据库中。...有时候需要在查询执行过程中对特定属性进行类型转换,例如需要从数据中获取数据的时候。

9K20

让LaravelLumen队列消费Non-Laravel queue job

如何让Laravel/Lumen作为消费者处理非Laravel/Lumen生产的消息?...小伙伴们应该都清楚在Laravel中的队列体系,是把实现了你的Job类进行序列化之后在队列中传输,消费者一方通过反序列化恢复对象,所以在Job类中我们可以完整传递信息,如Eloquent\Model 等...,但是如果生产者不是Laravel/Lumen体系的服务,投递到队列的消息也不是Queueable的对象,那Laravel Queue就无法正常解析,并且抛出异常。...为什么消费者是LaravelLaravel作为我们整套微服务体系的管理后台,既然是管理后台,当然还是单体式开发更舒适。再者管理后台已经聚集了所有数据对象的操作模型,那写消费者逻辑就更高效。...--- 其实对于Allow Laravel to process non-laravel queue job这个问题还是比较有普遍性,毕竟生产者和消费者不是用一个框架,甚至不同语种都是很正常的。

2.5K30

基于独立的 Laravel Eloquent 组件编写 ORM 模型类

模型类负责与数据库进行交互,这里的模型指的是数据的模型,一个模型类对应一张数据数据的字段会映射为模型类的属性,我们可以通过模型类提供的方法实现对应数据表记录的增删改查,这样一来,我们就将原来面向过程的数据库操作转化为面向对象风格的编程...,将对数据的 SQL 执行转化为对模型类的方法调用。...下载 Eloquent ORM 相关扩展包 Eloquent ORM 作为 Laravel 框架自带的 ORM 实现,还可以在 Laravel 框架之外作为独立的 ORM 组件使用。...初始化数据连接 首先我们在 app/bootstrap.php 中引入 Eloquent ORM 的 Capsule 类完成数据连接初始化,在此之前,先在配置文件 config/app.php 中调整数据连接配置符合...模型类全局可用(为了编写 Eloquent 模型类,如果只是使用 Laravel 提供的数据库查询构建器功能,则不需要这些操作)。

1.9K10

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

四、查询构建器Laravel框架中的Eloquent ORM提供了方便的查询构建器,用于构建复杂的查询语句。下面是一些常用的查询构建器方法。...join方法join方法用于关联查询,例如:$users = User::join('orders', 'users.id', '=', 'orders.user_id')->get();上述代码中,查询了用户和订单中符合条件的所有记录...总结通过上述文档和示例,我们可以看出Laravel框架中的Eloquent ORM提供了便捷的对象关系映射功能,可以大大简化开发者的数据库操作。...在使用Eloquent ORM进行开发时,需要注意以下几点:模型类名默认对应的名是模型类名的复数形式,如User模型对应的名是users,如果需要指定名可以通过定义$table属性来实现。...Eloquent ORM提供了大量的方法来操作数据,包括增删改查等,具体可以参考官方文档。

1.5K41

Laravel5.7 Eloquent ORM快速入门详解

简介 Laravel 内置的 Eloquent ORM 提供了一个美观、简单的与数据库打交道的 ActiveRecord 实现,每张数据都对应一个与该进行交互的模型(Model),通过模型类,你可以对数据进行查询...时间戳 默认情况下,Eloquent 期望 created_at 和 updated_at 已经存在于数据中,如果你不想要这些 Laravel 自动管理的数据列,在模型类中设置 $timestamps...这些方法返回单个模型实例不是模型集合: // 通过主键获取模型... $flight = App\Flight::find(1); // 获取匹配查询条件的第一个模型......这些方法返回计算后的结果不是整个模型实例: $count = App\Flight::where('active', 1)- count(); $max = App\Flight::where('active...、数据、以及数据连接: if ($post- is($anotherPost)) { // } 事件 Eloquent 模型可以触发事件,允许你在模型生命周期中的多个时间点调用如下这些方法:retrieved

15K41

orm 系列 之 Eloquent演化历程2

Blueprint和Builder,Schema/Builder负责提供数据库操作的面向对象似的操作,Schema/Blueprint则负责存储具体的操作数据,包括数据库操作的命令和数据的定义,因此有下面的结构...本文最后讲下Eloquent中新增的对象之间的关系:多态关系,以下内容摘自[ Laravel 5.3 文档 ] Eloquent ORM —— 关联关系 结构 多态关联允许一个模型在单个关联下属于多个不同模型...第一步addConnection,添加了默认的数据库配置,通过这个配置,我们可以通过DatabaseManager.connection来获取数据连接connection,从而进行操作。...Schema\Builder实例,然后进行正常的操作操作,此处Blueprint定义了蓝图,数据的定义,然后通过Blueprint.build来执行蓝图,从而产生数据。...User extends Eloquent { // } 此处Eloquent已经通过初始化设置了静态变量$resolver,我们可以方便的获取连接Connection了,也就是有了数据库操作的功能

2.4K30

通过 Laravel Eloquent 模型实现简单增删改查操作

「ActiveRecord」是 ORM 的一种实现模式,Eloquent 则是 Laravel 版的「ActiveRecord」。...一个 Eloquent 模型类映射一张数据,通过模型类提供的方法,你可以获取其映射的数据的所有记录,也可以获取单条记录,还可以创建、更新和删除对应数据表记录,而这一切都不需要你编写任何 SQL 语句...,其字段名为 id,如果你的数据主键名不是 id,可以通过 $primaryKey 属性来指定: protected $primaryKey = 'post_id'; 如果主键不是自增的,还可以设置...数据连接 Eloquent 模型类默认约定的数据连接是 config/database.php 中配置的默认连接,正如我们在连接配置教程中所说的那样,如果应用配置了多个数据连接,可以通过 $connection...属性为模型类指定使用哪个连接: protected $connection = 'connection_name'; 查询数据 日常开发中,大部分操作都是数据库中查询数据Eloquent 模型了为我们提供了很多方法帮助我们从数据库中获取数据

7.9K20

具有嵌套关系的可重用API资源——Laravel5.5

· 修改 .env 文件,使用 SQLite 数据库,并删除其他数据库相关的变量。· 添加或修改 DB_CONNECTION=sqlite 来指定 Laravel 使用 SQLite 作为数据连接。...这是在开发或测试阶段常用的操作,可以使用 Laravel 的 Seeder 来填充数据,确保数据库中有一些初始数据可用于开发和测试。 3....这样做有利于避免 N+1 查询问题(在获取关联数据时出现的效率问题),同时可以使用单个资源类处理不同的情况。如果关联数据可用,资源类会忽略它;反之,如果可用,资源类会将其包含在返回数据中。...简化和逐步进行本文着重于学习如何使用 Resource::collection 不是手动实例化类,并将关系数据的提供(或不提供)责任委托给控制器。...这暗示着对于数据包含的处理,Laravel 更多地依赖于控制器层面的逻辑,不是在资源转换层实现。

11610

Laravel 模型关联基础教程详解

要回答这个问题,首先你要知道有哪些可用的选项。Laravel 有 3 种不同的关联类型。 一对一 一对多 多对多 我们将逐个探讨不同的关联类型并解释一下应该什么时候使用它们。...账单可以包含多个产品,产品可以属于多个账单。 <?...invoices() { return $this- belongsToMany(App\Invoice::class); } } 多对多关联实现起来稍微困难一些,因为它们需要数据库中的中间...让我们使用前面的示例,但我们改变一件事:产品现在可以有多个历史条目不是一个。 数据保持不变。 <?...此属性表示中间,可以像任何其他模型一样使用。 举个例子,假设连接有 created_at 字段,我们就可以使用 pivot 来获取 created_at 字段。 <?

5.5K31

Laravel学习记录--Model

使用渴求式加载,即根据预先需求查询出所有数据 为了验证[渴求式加载]的好处,举下列例子 这里用到了Laravel Debugbar 调试 安装方法可参照我的另一个博客 - - - Laravel...Laravel中允许你自定义中间模型,需要注意的是中间模型与普通模型不一样 普通模型继承自Illuminate\Database\Eloquent\Model,中间模型继承自Illuminate...通过用户(users)这个中间,可以使国家与文章建立连接,因为用户分别与国家与文章建立了连接,即可通过用户(users)这个媒介,可使国家与文章建立连接 完成这个案例,我们先根据需求建...#touches: [] #hidden: [] #visible: [] #fillable: [] #guarded: array:1 [▶] } 当以方法访问关联关系时,这里返回不是...此方法会插入一条记录,但这条记录的uid为null,前提是uid字段允许为空,如果不允许为空会抛出异常 空对象模型 如果外键字段uid允许为空,当我们访问Phone模型上的muser属性(注意这里是属性,不是方法

13.4K20

Laravel源码分析之模型关联

上篇文章我们主要讲了Eloquent Model关于基础的CRUD方法的实现,Eloquent Model中除了基础的CRUD外还有一个很重要的部分叫模型关联,它通过面向对象的方式优雅地把数据之间的关联关系抽象到了...Eloquent Model中让应用依然能用Fluent Api的方式访问和设置主体数据的关联数据。...Eloquent里把主体数据的Model称为父模型,关联数据的Model称为子模型,为了方便下面所以下文我们用它们来指代主体和关联模型。...relations = [ 'author' => Collection(Author)//Author Model组成的集合 ]; 这样再使用动态属性引用已经预加载关联模型时就会直接从这里取出数据不用再去做数据库查询了...模型关联常用的一些功能的底层实现到这里梳理完了,Laravel把我们平常用的join, where in 和子查询都隐藏在了底层实现中并且帮我们把相互关联的数据做好了匹配。

9.5K10

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

本文实例讲述了laravel框架数据库操作、查询构建器、Eloquent ORM操作。...分享给大家供大家参考,具体如下: 1、连接数据laravel连接数据库的配置文件位于config/database.php中,在其中connection字段中包含laravel所支持的数据库的配置信息...如果要查询整个使用get(),查询中一条数据使用first(),查询一条数据的某个字段用value(),查询中所有数据的某个字段用pluck() //get()返回中所有数据 $res=DB::...Laravel内置的Eloquent ORM提供了一种便捷的方式帮助你组织数据数据,每张数据都对应一个与该进行交互的模型(Model),通过Model类,你可以对数据进行查询、插入、更新、删除等操作...Eloquent默认会管理数据的创建时间、更新时间,对应数据中的created_at、updated_at字段,你需要在创建时包含这两个字段。

13.3K51

Laravel系列4.3】模型Eloquent ORM的使用(一)

这样看貌似没问题呀,可是为什么报错的是 m_tests 不存在呢?这就牵涉到上面 Active Record 的概念了,在 AR 中,一个类对应的是一张一张是由多行数据组成的。...对于 Laravel 中标准的 Eloquent 模型类来说,每个都应该有两个字段,一个是 updated_at ,另一个是 created_at ,分别是两个时间戳字段,用于记录数据的创建时间和修改时间...这个原理我相信已经不用我多解释了,和 查询构造器 的不同就是这里是通过 Model 起步开始构造的,不是直接通过 DatabaseManager 起步的。...它就是去查询 db_sex 表里面的数据,然后把获得的结果对象返回回来。至于这个 ?...它判断的是这个 key 是否是抽象基类 laravel/framework/src/Illuminate/Database/Eloquent/Model.php ,不是我们定义的 MTest ,用的是一个

8.8K20

Laravel Eloquent 模型关联关系(下)

从性能上来说,渴求式加载更优,因为它会提前从数据库一次性查询所有关联数据懒惰式加载在每次查询动态属性的时候才会去执行查询,会多次连接数据库,性能上差一些(数据库操作主要开销在数据连接上,所以在开发过程中如果想优化性能...,尽量减少频繁连接数据库)。...,如果返回的文章结果是列表的话,需要遍历获取作者信息,假设要循环 N 次的话,加上文章模型本身的获取,总共需要进行 N + 1 次查询, PHP 对数据库的连接是短连接,每次都要重新连接数据库,所以从性能角度考虑不建议使用这种方式...另外,如果访问的是模型实例上的 author() 方法时,返回不是用户实例了,而是一个关联关系实例,该实例注入了查询构建器,所以你可以在其基础上通过方法链的方式构建查询构建器进行更加复杂的查询,我们以一个一对多的查询为例...所以不管模型实例有多少个,关联结果只会查询一次,加上模型本身查询总共是两次查询,在列表查询时,大大减少了对数据库的连接查询次数,因而有更好的性能表现,推荐使用。

19.5K30
领券