为了账号安全,请及时绑定邮箱和手机立即绑定

如何使用 Go 提取 postgres 时间戳范围?

如何使用 Go 提取 postgres 时间戳范围?

Go
杨__羊羊 2023-05-08 15:09:18
我有一个来自 postgres 的 tsrange 类型的数据库日历。它允许我有多个约会和时间范围,例如:["2018-11-08 10:00:00","2018-11-08 10:45:00"]如何将此值存储在 Go 变量中?我试过var tsrange []string当我登录时tsrange[0]它是空的。它的正确类型是什么?更多代码:rows, err := db.Query("SELECT * FROM appointments")utils.CheckErr(err)var id intvar userID intvar tsrange []stringrows.Next()err = rows.Scan(&id, &userID, &tsrange)fmt.Println(tsrange[0])当我var tsrange []string用var tsrange string日志替换时是["2018-11-08 10:00:00","2018-11-08 10:45:00"].
查看完整描述

1 回答

?
皈依舞

TA贡献1851条经验 获得超3个赞

您应该能够在 sql 级别检索范围的各个边界。


// replace tsrange_col with the name of your tsrange column

rows, err := db.Query("SELECT id, user_id, lower(tsrange_col), upper(tsrange_col) FROM appointments")

utils.CheckErr(err)


var id int

var userID int

var tsrange [2]time.Time


rows.Next()

err = rows.Scan(&id, &userID, &tsrange[0], &tsrange[1])


fmt.Println(tsrange[0]) // from

fmt.Println(tsrange[1]) // to


查看完整回答
反对 回复 2023-05-08
  • 1 回答
  • 0 关注
  • 108 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信