按日期过滤GORM

时间:2015-05-14 10:09:28

标签: database orm go go-gorm

我正在使用GORM来访问我的数据库中的记录。现在我想要检索所有未删除的记录,这意味着属性DeletedAt必须为NULL。

我使用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"`
}

1 个答案:

答案 0 :(得分:2)

对于所有RDBMS,SQL标准要求涉及与NULL值比较的条件始终为false。因此,以下查询始终返回空结果:

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)