侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

在laravel 10.20中firstOrCreate()与createOrFirst()的区别浅析

Laravel  /  管理员 发布于 1个月前   71

Laravel v10.20 推出了一个全新的方法 createOrFirst(),它是由 Tony Messias 提供的,可能会让人有些困惑,因为 Laravel 已经有了 firstOrCreate()。

有什么区别?为什么需要两个方法?让我们来看看...


createOrFirst()

新的 createOrFirst() 方法设计用于在高并发环境中更好地运行,并有助于减少竞赛条件,但需要对数据库进行唯一约束。

>通过 createOrFirst,我们反转了这一流程,并依赖于具有 UNIQUE 约束的表。
因此,首先,我们会尝试创建记录,如果从数据库得到异常反馈,
并确定违反了唯一性约束,我们就会尝试查找匹配的记录。
这样,并发进程就可以依赖数据库的 ACID 特性,再也不用担心出现竞赛条件了。

您可以在拉取请求中找到更多详细信息:

https://github.com/laravel/framework/pull/47973


firstOrCreate()

firstOrCreate 是最初的方法,文档中目前是这样定义的:

>firstOrCreate 方法将尝试使用给定的列/值对查找数据库记录。
如果在数据库中找不到模型,就会插入一条记录,
其属性是将第一个数组参数与可选的第二个数组参数合并后的结果。

这个新方法的另一个亮点是,原来的 firstOrCreate 方法现在使用了新的 createOrFirst 方法。

因此,它可以通过:

1.尝试查找
2.如果缺少,则尝试创建
3.如果出现 UNIQUE 违规,则尝试另一次查找,因为我们遇到了竞赛条件


总结

两种方法各自使用的场景,我认为在大多数应用程序中,使用原始的 firstOrCreate 就可以了,

只有在有大量流量的并发环境中,才真正需要使用 createOrFirst。


  • 上一条:
    Laravel 10.20版本发布
    下一条:
    Laravel字符串Wordwrap()方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Unfinalize 删除供应商软件包中类和方法的 "final "关键字(0个评论)
    • 适用于 Laravel 的表单请求测试程序包(0个评论)
    • Laravel 10.25版本发布(0个评论)
    • Laravel 11版本抢先看,看将有什么新功能发布(0个评论)
    • Laravel框架中适用于Eloquent的日期过滤软件包:lara-date-filter(0个评论)
    • 近期文章
    • 在go语言中计算相对强弱指数(RSI)示例代码(0个评论)
    • 在go语言中实现查找相关系数示例代码(0个评论)
    • 使用 Unfinalize 删除供应商软件包中类和方法的 "final "关键字(0个评论)
    • zongscan.com祝各位老铁2023中秋国庆假期快乐!(0个评论)
    • 在go语言中如何解析WSDL并调用对应的第三方接口(0个评论)
    • 使用cert Manager申请免费证书流程步骤(0个评论)
    • 在Nuxt3中如何减少import model声明及初始化加载models快速开发秘诀(0个评论)
    • 适用于 Laravel 的表单请求测试程序包(0个评论)
    • Laravel 10.25版本发布(0个评论)
    • 在go语言中实现生成文件的校验和功能代码示例(0个评论)
    • 近期评论
    • 路人 在

      php中使用hyperf框架调用讯飞星火大模型实现国内版chatgpt功能示例中评论 教程很详细,如果加个前端chatgpt对话页面就完美了..
    • 博主 在

      科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 @ mashrdn 多切换几个节点测试,免费ssr是没那么稳..
    • mashrdn 在

      科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 V2rayn免费节点添加上去了,youtobe无法打开网页,是怎么回事..
    • 张伟 在

      科学上网翻墙之v2rayN-Core客户端免费公益节点使用教程中评论 3q!有用,不过免费节点隔天就要去git上复制新的导进去..
    • 博主 在

      科学上网翻墙访问Google , 上外网神器佛跳墙VPN(永久免费)使用流程步骤中评论 该篇教程已不能用了,告知大家,免的老有老铁问我!..
    • 2016-10
    • 2016-11
    • 2017-07
    • 2017-08
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2020-10
    • 2020-11
    • 2021-01
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客