xorm 条件查询时区的问题

问题描述:如果在查询的时候,直接传时间格式作为条件,时间会被驱动程序转为UTC格式,因此会有8个小时的误差。

解决方案1:

将查询时间转为字符串

 
 

db.where("time > ?",  time.Now().Fomart("2006-01-02 15:04:05")).Get(&bean) 

解决方案2:

连接字符串增加loc=Asia%2fShanghai

 
 
func initEngine(cfg *config.Config) *xorm.Engine {
 dial := fmt.Sprintf("%v:%v@tcp(%v)/%v?charset=utf8&loc=%v", cfg.Mysql.Username,
cfg.Mysql.Password, cfg.Mysql.HostPort, cfg.Mysql.DBName, "Asia%2fShanghai")
engine, err := xorm.NewEngine("mysql", dial)
if err != nil {
panic(err)
}
engine.SetMaxOpenConns(cfg.Mysql.MaxConns)
engine.SetMaxIdleConns(cfg.Mysql.MaxIdle)
engine.ShowSQL(true)

engine.SetLogger(xorm.NewSimpleLogger(os.Stdout))
engine.Logger().SetLevel(core.LOG_DEBUG)
engine.SetMapper(core.GonicMapper{})
engine.SetTZLocation(time.Local)
return engine
}
参考源码: github.com/go-sql-driver/mysql/dsn.go github.com/go-sql-driver/mysql/packets.go

转载于:https://www.cnblogs.com/w3liu/p/11454967.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值