Golang GORM 实现类似于软删除的archived_at

golang gorm 实现类似于软删除的archived_at

问题内容

我正在使用 GORM V1。我有一个要求,我们想要添加一个类似于 GORM deleted_at 的 archived_at 列。实体可以存档和取消存档,默认情况下我们希望使用 archived_at 为 NULL 来查询记录。

我目前的想法是利用 GORM 回调来注册回调

在 gorm:query 回调之前注册回调。检查架构/模型是否需要 archived_at 字段。如果确实有该字段,请添加必要条件。

这听起来不错,但我如何有效地复制相当于存档的 Unscoped() 。

获取存档记录的惯用方法是什么?如何指示 archived_at 列是否应添加到必要的回调中?我还会遇到这样的情况:我只想获取存档记录(其中 archived_at IS NOT NULL)。

编辑 – 我的用例是同时使用 deleted_at 和 archived_at 字段,而不是使用一个字段代替另一个字段。我想保留软删除的能力,同时添加归档实体的能力。用户可能只是被存档,然后可能被删除(软删除)。

立即学习“go语言免费学习笔记(深入)”;

正确答案

邀请反馈。这是我目前想到的。

回调.go

package dbimport (    "fmt"    "reflect"    "gorm.io/gorm")const (    gormsettingkeyunscopearchive = "unscope_archive"    structfieldnamearchivedat    = "archivedat")// archivedquerycallback - conditionally adds "where archived_at is null" if the model being queried has the following// 1. struct field represented by structfieldnamearchivedat// 2. gorm instance setting gormsettingkeyunscopearchive, see unscopearchivefunc archivedquerycallback(db *gorm.db) {    // check if model is a pointer and has an indirect struct type    if db.statement.model != nil &&        reflect.typeof(db.statement.model).kind() == reflect.ptr &&        reflect.indirect(reflect.valueof(db.statement.model)).kind() == reflect.struct {        stmt := &gorm.statement{db: db}        parseerr := stmt.parse(db.statement.model)        if parseerr != nil {            panic(parseerr)        }        if _, archivedatexists := stmt.schema.fieldsbyname[structfieldnamearchivedat]; archivedatexists {            v, ok := db.instanceget(gormsettingkeyunscopearchive)            if ok {                if v == true {                    return                }            }            db.where(fmt.sprintf("%s is null", stmt.schema.fieldsbyname[structfieldnamearchivedat].dbname))        }    }}

登录后复制

范围.go

// unscopearchive - sets a true value for the key gormsettingkeyunscopearchivefunc unscopearchive(db *gorm.db) *gorm.db {    db = db.instanceset(gormsettingkeyunscopearchive, true)    return db}

登录后复制

main.go

   type User {       ID           string         `gorm:"primary_key" json:"id" valid:"uuidv4, optional"`    CreatedAt    time.Time      `valid:"-" json:"created_at"`    UpdatedAt    time.Time      `valid:"-" json:"-"`    DeletedAt    gorm.DeletedAt `sql:"index" valid:"-" json:"-"`    ArchivedAt   time.Time   }   var user []User   ctx := context.Background()   dbClient := InitializeGORM() //helper    _ := dbClient.WithContext(ctx).Find(&user).Error // SELECT * FROM users WHERE deleted_at IS NULL AND archived_at IS NULL;   _ := dbClient.WithContext(ctx).Scopes(UnscopeArchive).Find(&user).Error // SELECT * FROM users WHERE deleted_at IS NULL;

登录后复制

以上就是Golang GORM 实现类似于软删除的archived_at的详细内容,更多请关注【创想鸟】其它相关文章!

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

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2485794.html

(0)
上一篇 2025年3月4日 21:51:30
下一篇 2025年2月19日 11:39:28

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论