在go sqlx的where子句中检查参数是否为null

时间:2020-10-13 12:11:56

标签: postgresql go sqlx

鉴于我们在PostgreSQL数据库中有一条记录,如下所示:

name(varchar) nickname(nullable varchar)
John          null

我们要基于可空昵称值更新该记录,如下所示:

type Contact struct {
  Name     string         `db:"name"`
  Nickname sql.NullString `db:"nickname"`
}

func update() {
  db, _ := sqlx.Connect("postgres", "connection_string")

  c := Contact{
    Name: "Doe",
  }
  q := "UPDATE contact SET name = :name WHERE :nickname = '' AND nickname is null OR nickname = :nickname"

  db.NamedExec(db.Rebind(q), c)
}

仅当c.Nickname是字符串值(假设数据库中有匹配的记录)时,上面的查询才会更新记录。 如何实现这种逻辑:如果c.Nickname == nil使用nickname is null,否则使用nickname = c.Nickname

编辑:

我尝试了此查询UPDATE contact SET name = :name WHERE CAST(:nickname as varchar) is null AND nickname is null OR nickname = :nickname,它按预期运行,但仍想查看是否有更好的选择

0 个答案:

没有答案