database - 在 GORM 中按日期过滤

标签 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"`
}

最佳答案

对于所有 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)

关于database - 在 GORM 中按日期过滤,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30234610/

相关文章:

sql - 向 postgres 查询添加查询参数时出错

mysql - 在数据库建模中,它是什么样的关系?

sql - 数据库(最大)字段长度会影响性能吗?

php - Symfony 2创建子实体类对象时出错

python - Django-如何映射用户之间发送的消息

go - 是否可以使用标准库在 Go 中嵌套模板?

go - 像 [0 :2] 这样的 slice 声明

sql - 如何正确索引数据库以提高查询性能

database - 强制主键中的约束在 MS Access 中具有 "@"

python - 同一个 id 的多个外键。 Django 。设计模式