gorm 查询问题

发布于 2022-09-11 15:52:37 字数 1286 浏览 12 评论 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了,这个要怎么处理呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

随风而去 2022-09-18 15:52:37

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

も让我眼熟你 2022-09-18 15:52:37
  • 你定义了匿名变量的结构体,增加一个定义函数
func newJSONTime(t time.Time) JSONTime {
    return JSONTime{
        Time: t,
    }
}
  • 第二个问题中 c.DefaultPostForm 这个函数定义不清,排查问题先把
start, err := strconv.Atoi()

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


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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文