[扩展推荐] 为你的 Laravel 模型加上 Schemaless 属性(NoSQL 方案)

file

通过 Spatie 的 Laravel Schemaless Attributes Laravel 包, 你可以添加 schemaless 属性到 Eloquent 模型中了。它的 Readme 是这样介绍的:

如果你能够在 Eloquent 中使用 NoSQL 的话不会很酷吗?这个包就是这样做的。它提供了一个 trait ,能够在使用模型时保存任意值到单个 JSON 字段中。

由于该软件包需要支持 json 格式字段的数据库,因此你需要使用像 MySQL 5.7 或更高版本的数据库。

你可以像设置属性一样去获取或设置 schemaless 属性:

$yourModel->extra_attributes->name = 'value';
$yourModel->extra_attributes->name; // 返回 'value'

要保存 schemaless 属性,直接保存模型就好了:

// 其他设置都保持不变
$yourModel->save();

当我开始测试这个包的时候碰到的一个问题是查询模型的额外属性:

$yourModel->withExtraAttributes([
    'name' => 'value',
    'name2' => 'value2
])->get();

要使用这个包,你需要使用 Composer 安装:

composer require spatie/laravel-schemaless-attributes

接下来,你需要像以下这样添加到需要使用 JSON 属性的模型迁移文件中:

Schema::table('your_models', function (Blueprint $table) {
    $table->schemalessAttributes('extra_attributes');
});

你可以查看文档去获取需要配置 schemaless 属性到模型的额外操作,如果你打算在多个模型上使用 schemaless ,该文档会向你展示如何为额外属性访问器和作用域创建 trait 。

这个包提供了一种在关系型数据库中添加、访问和保留 schemaless 数据的功能,并提供了有关 JSON 数据的简便方法,请到 GitHub 查看完整文档和源码。


Practice makes perfect.

原文地址:https://laravel-news.com/laravel-schemal...

译文地址:https://learnku.com/laravel/t/12252/exte...

本帖已被设为精华帖!
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 2
Destiny

对 json 格式字段的一系列操作。

1年前 评论
Destiny

之前觉得 json 格式的字段处理有点麻烦,有这个包就方便多了。

1年前 评论

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!

社区文档:

将托管在 packagist.org 和 github.com 的扩展包使用国内 CDN 加速
GitHub Laravel 扩展包 TOP 250
速查表方便快速查询框架功能,支持手机访问,支持中英文版本
Laravel 中文文档,由社区用户翻译和维护,将会保持一直更新
此文档的目的,就是为了提高技术团队的凝聚力、一致性和生产效率。
开发环境的部署,开发者工具的选择,适用于 Mac 和 Windows。
浓缩过后的精华
Laravel Nova 后台管理面板文档的中文翻译
Lumen 中文文档,由社区用户翻译和维护,将会保持一直更新
Laravel 下知名扩展包 Dingo API 的中文文档,Laravel API 开发必知必会