0
package main

import (
    "database/sql/driver"
    "fmt"
    "time"
)

type JSONTime struct {
    time.Time
}

// MarshalJSON on JSONTime format Time field with %Y-%m-%d %H:%M:%S
func (t JSONTime) MarshalJSON() ([]byte, error) {
    formatted := fmt.Sprintf("\"%s\"", t.Format("2006-01-02 15:04:05"))
    return []byte(formatted), nil
}

// Value insert timestamp into mysql need this function.
func (t JSONTime) Value() (driver.Value, error) {
    var zeroTime time.Time
    if t.Time.UnixNano() == zeroTime.UnixNano() {
        return nil, nil
    }
    return t.Time, nil
}

// Scan valueof time.Time
func (t *JSONTime) Scan(v interface{}) error {
    value, ok := v.(time.Time)
    if ok {
        *t = JSONTime{Time: value}
        return nil
    }
    return fmt.Errorf("can not convert %v to timestamp", v)
}

type TimeTest struct {
    Id            int64 `gorm:"primary_key"`
    CreatedAt     JSONTime
}

gorm Time.Time 类型换成了JSONTime.这个通过JSON输出会转化成2006-01-02 15:04:05这样的格式.那我现在如何对这个CreatedAt赋值呢?或者说如何通过string或者time类型转化成JSONTime类型

start, _ := strconv.Atoi(c.DefaultPostForm("start", time.Now().Format("2006-01-02") + " 05:00:00"))
Db.Model(&User).Where("time >= ?",start)

上面的start在sql中被自动转化成0了,这个要怎么处理呢?

cxy888 11
2018-12-03 提问

查看全部 2 个回答

0

实在是不明白,你为什么要JsonTime, time.Time不行吗??
这个start参数,本身就是要最外层去过滤空值的。
还有就是在gorm中 created_at 和 update_at 不需要手动赋值。

推荐答案

0

已采纳
  • 你定义了匿名变量的结构体,增加一个定义函数
func newJSONTime(t time.Time) JSONTime {
    return JSONTime{
        Time: t,
    }
}
  • 第二个问题中 c.DefaultPostForm 这个函数定义不清,排查问题先把
start, err := strconv.Atoi()

中的 err 打印出来,不能保证绝对没有错误,就不要忽略 golang 中的 error


另外说个题外话,sql 语句最好别用函数封装,排查问题比较蛋疼

推广链接