gorm 查询问题
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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
实在是不明白,你为什么要JsonTime, time.Time不行吗??
这个start参数,本身就是要最外层去过滤空值的。
还有就是在gorm中 created_at 和 update_at 不需要手动赋值。
c.DefaultPostForm
这个函数定义不清,排查问题先把中的 err 打印出来,不能保证绝对没有错误,就不要忽略 golang 中的 error
另外说个题外话,sql 语句最好别用函数封装,排查问题比较蛋疼