目录
分页
在model里面增加自定义值" >在model里面增加自定义值
为不存在列增加一个变异器(属性设置器)
渴求式加载: with $with
modelKeys 方法
首页 php框架 Laravel 6个Laravel Eloquent小技巧,助你提高代码可读性!

6个Laravel Eloquent小技巧,助你提高代码可读性!

Nov 15, 2022 pm 08:07 PM
php laravel

本篇文章整理分享六个能提高代码可读性的 Laravel Eloquent 小技巧,希望对大家有所帮助!

6个Laravel Eloquent小技巧,助你提高代码可读性!

Eloquent是Laravel默认使用的ORM。采用了活动记录模式。让你可以以一种更加轻松的方式与数据库进行交互。每个单独的模型都表示数据库中的一个表,你可以使用该表进行操作。在这篇文章中,我们将或多或少地向你展示你可能不知道的隐藏秘密、方法和属性,以改进你的代码。

蛇形命名 属性

蛇形命名属性是一个有趣的属性。让我们看看代码是怎么说的:

/**
 * 指示是否在数组上使用蛇形大小写属性。
 *
 * @var bool
 */
public static $snakeAttributes = true;
登录后复制

人们经常会错误地使用这个属性来更改访问属性的方式。许多人认为,如果更改这个属性,就可以使用驼峰式注释轻松访问属性。事实并非如此。我们强烈建议你不要使用它。当模型作为数组输出时,只需定义属性是驼峰式还是蛇形即可。

如果你想基于驼峰式命名,我们建议你查看 Kirk Bushell 的软件包 Eloquence by Kirk Bushell.

分页

如果你正在使用 Laravel 的 Eloquent ORM,那这对你是个好消息。 它提供了一种开箱即用的分页方法。你可能很熟悉这样的写法:

$comments = Comment::paginate(20);
登录后复制

使用此方法,你可以每页20个条目来为 comment model 分页。更改该值可以定义每页显示多少条数。如果不指定任何内容,则应用默认值,即15。

假设您希望在网站上的多个位置显示评论。每页总是有30条评论。如果必须在每个地方传递参数30,那就麻烦了。因此,您可以直接在模型上设置新的默认值。

protected $perPage = 30;
登录后复制

Eloquent有一个称为“访问器”的强大功能。该功能允许你向模型或表中不存在的模型添加自定义字段。使用现有的值或定义全新的值都不重要,随时都可以回退。下面是访问器如何工作的示例。假设有一个名为user的模型,我们给他添加一个FullName的访问器:

function getFullNameAttribute() {
    return sprintf('%s %s', $this->first_name, $this->last_name);
}
登录后复制

现在你可以访问post模型上的full_name属性,如下:

User::latest()->first()->full_name;
登录后复制

如果返回对象(如集合),则此属性不会附加到用户模型。将protected$appends属性添加到模型中。它接受一个数组,其中包含一个或多个字段,从现在起应该自动追加这些字段。写成这样就可以了:

protected $appends = ['full_name'];
登录后复制

为不存在列增加一个变异器(属性设置器)

变异器与获取器相反。你可以用它做些很有意思的事情。 举个例子,转换不同类型的输入。 让我来给你详细说说。假设你想要保存一种类型的时间段。通常,你总是保存尽可能小的单位。在我们的案例中是秒。由于UX的原因,用户不想输入秒,例如在一个地方输入分钟,或者在另一个地方输入小时。这一切都可以很快解决。

class Video extends Model
{
    public function setDurationInMinutes($value)
    {
        $this->attributes['duration_in_seconds'] = $value * 60;
    }

    public function setDurationInHours($value)
    {
        $this->attributes['duration_in_seconds'] = $value * 60 * 60;
    }
}
登录后复制

上述代码意味着你可以使用一个不存在于数据表本身的字段。
model中使用的是duration_in_minutes字段,但是在后台,我们使用duration_in_seconds进行更新,也有可能使用一个不存在字段duration_in_hours。根据这个逻辑,我们在Controller如此调用:

class AnyController
{
    public function store()
    {
        $video->update([
            'title' => request('title'),
            'duration_in_minutes' => request('duration_in_minutes'),
        ]);
    }
}
登录后复制

这将节省你在控制器中进行计算的时间,你可以简单地使用不存在的列,并在执行某些计算时使用变异器将其结果映射到正确的字段上。

渴求式加载: with $with

让我们来谈谈关联关系。默认情况下,Laravel使用延迟加载。就关联关系而言,这意味着什么?延迟加载的好处是可以节省内存,因为并不是所有的数据都需要保留,我们可以在需要的时候加载数据。如下:

$comments = Comment::all();
foreach ($comments as $comment) {
    echo $comment->user->name;
}
登录后复制

在上面的例子中,我们会获取所有评论数据。然后遍历评论并显示每个评论的用户名。这段代码没什么问题,可以正常工作,但我们遇到了一个问题。延迟加载现在确保仅当我们想要输出用户名时才执行获取用户的查询。

欢迎来到你的第一个 N+1 问题。为什么是 N+1?N 始终是评论的数量,1 是获取评论的查询。例如,如果我们有500个评论,那么获取所有评论的查询被触发一次,然后一个查询获得相应的user-per评论。所以500+1查询。这意味着随着注释数量的增加,查询的数量也会增加。

为了防止出现这种情况,有一种称为渴求式加载的方法。

$comments = Comment::with('user')->get();
foreach ($comments as $comment) {
    echo $comment->user->name;
}
登录后复制

这会以两个查询结束。第一个查询获取所有注释,第二个查询立即获取所有关联用户。在后台,会发生以下情况(简化版SQL):

SELECT id, user_id, body FROM comments;
SELECT name FROM users WHERE user_id IN (1,2,3,4,5...);
登录后复制

不论是 10、500 还是 10000 条评论数据都不重要,我们都依旧只执行两次SQL查询。

好了,你现在已经看到如何使用渴求式加载了。但只限于如何手动使用。你还可以将整个过程自动化,以便某些关联关系总是自动通过渴求式方式加载。为此,需要给模型设定一个属性。

protected $with = [];
登录后复制

我们可以在Comment model简单设置 protected $with = ['user'];, 从现在起,user在任何时候都会自动加载。

我们还有很多种渴求式加载,有仅加载特定列、嵌套即时加载、多个即时加载等等。更多详情请Laravel文档或深入核心。

modelKeys 方法

有的时候需要查询所有的主键 ID, 查询是否复杂并不重要,大多数人可能会像这样做:

User::all()->pluck('id');
登录后复制

这个操作很 nice,但是返回的是一个集合,想要转换成数组的话可以使用 toArray()

User::all()->pluck('id')->toArray();
登录后复制

大多数情况下,上面的操作的可以简化成这样:

User::all()->modelKeys();
登录后复制

这种方式返回一个数组。重要的是这个方法并不会总是返回 id。 顾名思义,他是以数组的形式返回所有模型主键。主键默认是id,同时也可以在模型中定义主键名。

protected $primaryKey = 'id';
登录后复制

原文地址:https://laravel-news.com/6-eloquent-secrets

译文地址:https://www.php.cn/link/c7decb5ce28209911b545d0b1059c5e3

【相关推荐:laravel视频教程

以上是6个Laravel Eloquent小技巧,助你提高代码可读性!的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP和Python:比较两种流行的编程语言 PHP和Python:比较两种流行的编程语言 Apr 14, 2025 am 12:13 AM

PHP和Python各有优势,选择依据项目需求。1.PHP适合web开发,尤其快速开发和维护网站。2.Python适用于数据科学、机器学习和人工智能,语法简洁,适合初学者。

PHP:网络开发的关键语言 PHP:网络开发的关键语言 Apr 13, 2025 am 12:08 AM

PHP是一种广泛应用于服务器端的脚本语言,特别适合web开发。1.PHP可以嵌入HTML,处理HTTP请求和响应,支持多种数据库。2.PHP用于生成动态网页内容,处理表单数据,访问数据库等,具有强大的社区支持和开源资源。3.PHP是解释型语言,执行过程包括词法分析、语法分析、编译和执行。4.PHP可以与MySQL结合用于用户注册系统等高级应用。5.调试PHP时,可使用error_reporting()和var_dump()等函数。6.优化PHP代码可通过缓存机制、优化数据库查询和使用内置函数。7

PHP的当前状态:查看网络开发趋势 PHP的当前状态:查看网络开发趋势 Apr 13, 2025 am 12:20 AM

PHP在现代Web开发中仍然重要,尤其在内容管理和电子商务平台。1)PHP拥有丰富的生态系统和强大框架支持,如Laravel和Symfony。2)性能优化可通过OPcache和Nginx实现。3)PHP8.0引入JIT编译器,提升性能。4)云原生应用通过Docker和Kubernetes部署,提高灵活性和可扩展性。

PHP与其他语言:比较 PHP与其他语言:比较 Apr 13, 2025 am 12:19 AM

PHP适合web开发,特别是在快速开发和处理动态内容方面表现出色,但不擅长数据科学和企业级应用。与Python相比,PHP在web开发中更具优势,但在数据科学领域不如Python;与Java相比,PHP在企业级应用中表现较差,但在web开发中更灵活;与JavaScript相比,PHP在后端开发中更简洁,但在前端开发中不如JavaScript。

PHP的持久相关性:它还活着吗? PHP的持久相关性:它还活着吗? Apr 14, 2025 am 12:12 AM

PHP仍然具有活力,其在现代编程领域中依然占据重要地位。1)PHP的简单易学和强大社区支持使其在Web开发中广泛应用;2)其灵活性和稳定性使其在处理Web表单、数据库操作和文件处理等方面表现出色;3)PHP不断进化和优化,适用于初学者和经验丰富的开发者。

PHP:许多网站的基础 PHP:许多网站的基础 Apr 13, 2025 am 12:07 AM

PHP成为许多网站首选技术栈的原因包括其易用性、强大社区支持和广泛应用。1)易于学习和使用,适合初学者。2)拥有庞大的开发者社区,资源丰富。3)广泛应用于WordPress、Drupal等平台。4)与Web服务器紧密集成,简化开发部署。

PHP与Python:核心功能 PHP与Python:核心功能 Apr 13, 2025 am 12:16 AM

PHP和Python各有优势,适合不同场景。1.PHP适用于web开发,提供内置web服务器和丰富函数库。2.Python适合数据科学和机器学习,语法简洁且有强大标准库。选择时应根据项目需求决定。

PHP的目的:构建动态网站 PHP的目的:构建动态网站 Apr 15, 2025 am 12:18 AM

PHP用于构建动态网站,其核心功能包括:1.生成动态内容,通过与数据库对接实时生成网页;2.处理用户交互和表单提交,验证输入并响应操作;3.管理会话和用户认证,提供个性化体验;4.优化性能和遵循最佳实践,提升网站效率和安全性。

See all articles