数据库用的 postgresql,字段类型为:TIMESTAMP
因为这一列的值可能存在null
所以在 scan 的时候这一列的变量类型定义为:sql.NullString
,这样最后如果有值的话得到的数据为这样的格式:"xxxx-xx-xxTxx:xx:xxZ"
这样会报错:time.Parse("layout", "xxxx-xx-xxTxx:xx:xxZ")
写时间 v 站就要让验证手机号:所以上面的时间和 layout 没写具体的值
1
kungfuchicken 2019-05-13 13:36:19 +08:00
每个字都看懂了,但是我没看懂你在问啥
|
2
imherer OP @kungfuchicken 刚才一直在编辑主题,里面不知道里面哪个时间写的不对,v 站一直让验证手机
|
3
imherer OP @kungfuchicken 想把这个直接格式化成北京时间
|
4
www5070504 2019-05-13 13:40:30 +08:00
没有指定时间格式的转换成时间戳的参数么
|
5
imherer OP @www5070504 我也刚接触 go 不久,官方的``time``包找了下好像是没有。 第三方的不清楚有没有。
|
6
lcdtyph 2019-05-13 13:45:59 +08:00 via iPhone
我猜你要找的是 strptime,不知道 go 有没有
|
7
imherer OP @lcdtyph 解决了,是前面 layout 不对。我 layout 用的 xxxx-xx-xx xx:xx:xx,这里需要用 xxxx-xx-xxTxx:xx:xxZ
|
8
reus 2019-05-13 16:16:42 +08:00
用 SQL 表达式 extract(epoch from xxx)::bigint 就可以返回时间戳,不用在 go 代码里解析
|
9
reus 2019-05-13 16:22:39 +08:00
数据库返回的不一定是 "xxxx-xx-xxTxx:xx:xxZ" 格式。默认应该是 ISO 格式的,你这里不知道是哪里转换成了 ISO 8601 格式。你要确定数据库和程序库会一直输出 ISO 8601 格式才行,不然以后可能会出错。
|
10
keepeye 2019-05-13 16:46:29 +08:00
没错,go 从数据库读出来的时间显示格式就是 tz 格式,很恶心,要自己 parse 再 format 成 datetime 格式
|
11
keepeye 2019-05-13 16:46:58 +08:00
不过我建议你字段类型直接设置成 *time.Time,不用字符串,省了再去 parse
|
12
learnshare 2019-05-13 17:01:07 +08:00
|
13
keepeye 2019-05-13 17:09:27 +08:00
@learnshare 变量类型是 time.Time 没问题。问题是 string 类型的,为什么要转成这种格式呢? mysql 的 timestamp 模式显示格式不是 yyyy-mm-dd hh:ii:ss 吗?
|
14
Mitt 2019-05-13 18:37:32 +08:00 via iPhone
@learnshare 问题不应该是 time.Parse 不能用这个值反格式化吗
|
15
learnshare 2019-05-13 19:01:51 +08:00
|
16
heimeil 2019-05-13 19:08:59 +08:00
time.RFC3339
|
18
imherer OP |
19
imherer OP |
20
rrfeng 2019-05-13 20:09:39 +08:00
这肯定是 layout 有问题啊……
|
21
YakuMioto 2019-05-13 20:14:12 +08:00 via Android
2006-01-02T13:04:05Z
|