duanfei8897 2018-04-06 11:14
浏览 474
已采纳

如何从没有时区的Postgresql中获取时间戳值?

I have a table with timestamp TIMESTAMP, data TEXT columns. I have a failing test because I can't get a timestamp value out of postgresql without time zone annotation. Here's an abridged version of what I've done in my Go application:

type Datapoint struct {
    Timestamp  string
    Data       sql.NullString
}
var testData = Datapoint{Timestamp:'2018-12-31 00:00:00', Data:'test'}

db.Exec("CREATE TABLE mytable (id SERIAL, timestamp TIMESTAMP, data TEXT);")
db.Exec("INSERT INTO mytable(timestamp, data) VALUES ($1, $2);", testData.Timestamp, testData.Data)
datapoints, err = db.Exec("SELECT timestamp::TIMESTAMP WITHOUT TIME ZONE, data FROM mytable;")

This trouble is that this query (after about 20 lines of error checking and row.Scan; golang's a bit verbose like that...) gives me:

expected 2018-12-31 00:00:00, received 2018-12-31T00:00:00Z

I requested without timezone (and the query succeeds in psql), so why am I getting the extra T and Z in the string?

  • 写回答

2条回答 默认 最新

  • duanpang5583 2018-04-06 11:52
    关注

    Scan into a value of time.Time instead of string, then you can format the time as desired.

    package main
    
    import (
        "database/sql"
        "fmt"
        "log"
        "time"
    )
    
    type Datapoint struct {
        Timestamp time.Time
        Data      sql.NullString
    }
    
    func main() {
        var db *sql.DB
    
        var dp Datapoint    
        err := db.QueryRow("SELECT timestamp, data FROM mytable").Scan(
            &dp.Timestamp, &dp.Data,
        )
    
        switch {
        case err == sql.ErrNoRows:
            log.Fatal("No rows")
        case err != nil:
            log.Fatal(err)
        default:
            fmt.Println(dp.Timestamp.Format("2006-01-02 15:04:05"))
        }
    
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥50 易语言把MYSQL数据库中的数据添加至组合框
  • ¥20 求数据集和代码#有偿答复
  • ¥15 关于下拉菜单选项关联的问题
  • ¥20 java-OJ-健康体检
  • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
  • ¥15 使用phpstudy在云服务器上搭建个人网站
  • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
  • ¥15 vue3+express部署到nginx
  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况