mysql - sql:列索引6上的扫描错误,名称“scheduled_date”:null:无法将类型[] uint8扫描到null.Time
问题描述
我收到此错误并尝试了 Internet 和 stackoverlow 中可用的所有内容来解决此问题。我试图在使用 sqlx 包连接 MySQL db 并扫描结果后运行查询。我已经尝试过针对类似问题共享的解决方案,但对我没有任何帮助。
type Trip struct {
ID int `db:"id"`
Type int `db:"type"`
DID int `db:"did"`
DUID int `db:"duid"`
VID int `db:"vid"`
Sts string `db:"sts"`
AM int `db:"am"`
Sdate null.Time `db:"sdate"`
}
func GetTripByID(db sqlx.Queryer, id int) (*Trip, error) {
row := db.QueryRowx("select ID,Type,DID,DUID,VID,Sts,AM,Sdate from mytbl where ID=123", id)
var t Trip
err := row.StructScan(&t)
if err != nil {
fmt.Println("Error during struct scan")
return nil, err
}
return &t, nil
}
我得到的确切错误是
恐慌:sql:列索引6上的扫描错误,名称“sdate”:null:无法将类型[]uint8扫描为null。时间:[50 48 49 56 45 49 50 45 48 55 32 48 50 58 48 56 58 53 49]
语法方面,查询工作得很好,当我在 sql 工作台中运行它时,我得到了结果。我还尝试了 ParseTime=true 作为链接之一的建议。
解决方案
尝试对包“database/sql”中的空值使用特殊类型
例如,当 db 中的 text 或 varchar 可以为 null 时,使用 sql.NullString 作为 var 类型。
推荐阅读
- reactjs - 使用 useReducer 手动获取数据
- python-3.x - OptionMenu 变量未在 tkinter 中分配值
- r - 如何在R中获得5位数字的茎叶图?
- postgresql - PostgreSQL:清除快照
- azure - MS Teams 聊天机器人自定义授权
- typescript - 类验证器是如何工作的?
- luigi - 带有单独任务的 Luigi 依赖项规范问题
- powershell - 文件中的 SecureString“随机”停止工作
- sas - SAS将数字变量覆盖为字符
- java - Jira ServiceDesk 用户创建 - 此资源需要 WebSudo