乐闻世界logo
搜索文章和话题

如何恢复通过gorm deletedAt软删除的数据

5 个月前提问
5 个月前修改
浏览次数23

1个答案

1

要恢复使用gorm的 deletedAt字段进行软删除的数据,您可以通过以下几个步骤来实现:

  1. 查询被软删除的数据: 在gorm中,默认情况下,查询操作会自动忽略那些被软删除的数据(即 deletedAt字段不为null的数据)。要查询这部分数据,您需要使用 Unscoped方法来获取所有的数据,包括被软删除的。

    go
    var user User db.Unscoped().Where("id = ?", userID).Find(&user)

    这里的 User是模型名称,userID是您要恢复的数据的ID。

  2. 复原数据: 将查询到的数据中的 deletedAt字段设置为null,这样可以复原数据,使其重新可见。

    go
    db.Model(&user).Update("deletedAt", nil)

    这样就会将该条记录的 deletedAt字段更新为null,即表示该数据未被删除。

示例:

假设您有一个用户管理系统,其中用户的数据模型 User使用了gorm的软删除功能。现在要恢复ID为123的用户,可以按照以下代码示例操作:

go
package main import ( "gorm.io/gorm" "gorm.io/driver/sqlite" "time" ) type User struct { gorm.Model Name string } func main() { db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{}) if err != nil { panic("数据库连接失败") } var user User // 查询被软删除的数据 db.Unscoped().Where("id = ?", 123).Find(&user) if user.ID != 0 { // 恢复数据 db.Model(&user).Update("DeletedAt", nil) println("用户数据已恢复") } else { println("未找到指定用户") } }

在这个例子中,我们首先使用 Unscoped并指定ID来找到被软删除的用户数据,然后使用 Update方法将 DeletedAt设置为null来恢复这条记录。

通过这种方式,您可以灵活地恢复任何被软删除的数据,并且这个过程可以很方便地与您的业务逻辑集成。

2024年8月12日 17:20 回复

你的答案