donglun1918 2015-05-14 10:09
浏览 677
已采纳

在GORM中按日期过滤

I'm using GORM to access the records in my database. Now I want to retrieve all records that are not deleted which means, that the attribute DeletedAt must be NULL.

I tried the following command chains with WHERE(), but they returned no results.

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

and

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

My database model is defined by the following structs:

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条回答 默认 最新

  • donglizhan7848 2015-05-14 12:31
    关注

    With all RDBMS, the SQL standard mandates that a condition involving a comparison with a NULL value is always false. The following query therefore always returns an empty result:

    select * from XXX where deleted_at = NULL
    

    If you want to search for NULL values, you are supposed to write:

    select * from XXX where deleted_at is null
    

    I think you can fix the issue by making sure GORM generates the correct query. For instance, this should work (untested):

    db.Where("deleted_at is null").Find(&users)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题