0

0

孟加拉语中的 Laravel Eloquent ORM 部分 - 插入和更新模型)

心靈之曲

心靈之曲

发布时间:2025-01-16 22:14:01

|

1155人浏览过

|

来源于php中文网

原创

孟加拉语中的 laravel eloquent orm 部分 - 插入和更新模型)

Laravel Eloquent 提供便捷的模型插入和更新数据库表数据的方法。以下详细介绍其使用方法。

模型插入 (添加数据)

1. 创建新记录 (使用 save() 方法)

save() 方法用于创建并保存 Eloquent 模型。

use App\Models\Post;

// 创建新文章
$post = new Post();
$post->title = '新博客文章';
$post->content = '这是文章内容。';
$post->status = '草稿';

// 保存数据
$post->save();

save() 方法在为模型赋值后调用,从而在数据库中创建新记录。

2. 简洁方法 (使用 create() 方法)

create() 方法直接将数据插入单行。

use App\Models\Post;

Post::create([
    'title' => '快速博客文章',
    'content' => '这是内容。',
    'status' => '已发布',
]);
注意:使用 create() 方法时,请在模型中定义可填充或受保护属性。

3. 添加多条记录 (批量插入)

insert() 方法一次性插入多条记录。

use App\Models\Post;

Post::insert([
    ['title' => '文章 1', 'content' => '内容 1', 'status' => '已发布'],
    ['title' => '文章 2', 'content' => '内容 2', 'status' => '草稿'],
]);

模型更新 (更新数据)

1. 更新特定记录 (使用 save() 方法)

从数据库获取模型后,即可更新其数据。

use App\Models\Post;

// 查找记录
$post = Post::find(1);

// 更新数据
$post->title = '已更新的博客文章';
$post->status = '已发布';

// 保存
$post->save();

2. 使用 update() 方法更新

update() 方法直接更新多列。

Bika.ai
Bika.ai

打造您的AI智能体员工团队

下载
use App\Models\Post;

Post::where('id', 1)->update([
    'title' => '更新后的标题',
    'status' => '已发布',
]);

3. 更新多条记录

update() 方法也可用于更新多条记录。

use App\Models\Post;

Post::where('status', '草稿')->update(['status' => '已存档']);

无需检索的插入或更新 (upsert)

upsert() 方法用于添加新数据或更新现有数据,无需先检索记录。

use App\Models\Post;

Post::upsert([
    ['id' => 1, 'title' => '更新标题 1', 'status' => '已发布'],
    ['id' => 2, 'title' => '更新标题 2', 'status' => '草稿'],
], ['id'], ['title', 'status']);

说明:

  • 第一个参数:要插入或更新的数据。
  • 第二个参数:用于识别现有记录的键。
  • 第三个参数:要更新的列。

时间戳和软删除处理

1. 时间戳自动更新

Laravel 默认更新 created_atupdated_at 列。

$post = Post::find(1);
$post->status = '已存档';
$post->save(); // `updated_at` 列自动更新

2. 软删除处理

如果模型启用了软删除,deleted_at 列将被更新,而不是删除数据。

$post->delete(); // 软删除

批量插入和更新最佳实践

  • 使用数据库事务:进行多个操作时,使用数据库事务确保数据一致性。
DB::transaction(function () {
    Post::create([...]);
    Post::update([...]);
});
  • 数据验证:在插入或更新之前验证数据。
  • 使用批量赋值保护:正确使用 $fillable$guarded 属性。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

313

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

270

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

363

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

363

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

80

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

63

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

62

2025.08.05

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

330

2023.06.29

桌面文件位置介绍
桌面文件位置介绍

本专题整合了桌面文件相关教程,阅读专题下面的文章了解更多内容。

0

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Laravel---API接口
Laravel---API接口

共7课时 | 0.6万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号