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

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

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

模型插入 (添加数据)

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

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

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

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

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

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

use AppModelsPost;Post::create([    'title' => '快速博客文章',    'content' => '这是内容。',    'status' => '已发布',]);

注意:使用 create() 方法时,请在模型中定义可填充或受保护属性。

<?phpnamespace AppModels;use IlluminateDatabaseEloquentModel;class Post extends Model{    protected $fillable = ['title', 'content', 'status'];}

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

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

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

模型更新 (更新数据)

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

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

use AppModelsPost;// 查找记录$post = Post::find(1);// 更新数据$post->title = '已更新的博客文章';$post->status = '已发布';// 保存$post->save();

2. 使用 update() 方法更新

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

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

3. 更新多条记录

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

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

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

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

use AppModelsPost;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 Eloquent ORM 部分 – 插入和更新模型)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1252476.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月10日 00:02:45
下一篇 2025年12月10日 00:02:59

相关推荐

发表回复

登录后才能评论
关注微信