【问题标题】:Filtering by date in GORM在 GORM 中按日期过滤
【发布时间】:2015-05-14 10:09:28
【问题描述】:

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

【问题讨论】:

    标签: database orm go go-gorm


    【解决方案1】:

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

    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)
    

    【讨论】:

      猜你喜欢
      • 2013-11-25
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-09-08
      • 2019-03-01
      • 2016-01-10
      相关资源
      最近更新 更多