过滤按日期GORM(Filtering by date in GORM)

2019-10-23 02:34发布

我使用GORM访问我的数据库中的记录。 现在我想检索不会被删除,这意味着,该属性DeletedAt必须是空的所有记录。

我想下面的命令链与WHERE()但他们没有返回结果。

users := []*models.User{}
db.Where("deleted_at", nil).Find(&users)

db.Where("deleted_at", "NULL").Find(&users)

我的数据库模型由以下结构定义:

type Model struct {
    ID        uint `gorm:"primary_key"`
    CreatedAt time.Time
    UpdatedAt time.Time
    DeletedAt *time.Time
}

type User struct {
    gorm.Model
    Username string `sql:"size:32; not null; unique"`
    Password string `sql:"not null"`
    Locale   string `sql:"not null"`
}

Answer 1:

对于所有RDBMS,一个条件涉及与NULL值的比较SQL标准规定始终是假的。 下面的查询,因此总是会返回一个空的结果:

select * from XXX where deleted_at = NULL

如果你要搜索NULL值,你应该这样写:

select * from XXX where deleted_at is null

我想你可以通过确保GORM生成正确的查询解决问题。 举例来说,这应该工作(未经测试):

db.Where("deleted_at is null").Find(&users)


文章来源: Filtering by date in GORM