登录
首页 >  Golang >  Go问答

SQL错误:在列索引 6 上扫描“scheduled_date”时出错,无法将 uint8 类型转换为 null.Time

来源:stackoverflow

时间:2024-03-15 21:03:28 311浏览 收藏

在使用 SQLx 包扫描数据库结果时,用户遇到了一个错误,提示无法将 uint8 类型转换为 null.Time。该错误与列索引 6 上的“scheduled_date”字段相关。用户已尝试各种解决方案,包括使用 parsetime=true,但仍然无法解决问题。

问题内容

我收到此错误并尝试了互联网和 stackoverlow 中可用的所有方法来解决此问题。我正在尝试使用 sqlx 包连接 mysql 数据库后运行查询并扫描结果。我已经尝试过针对类似问题分享的解决方案,但对我来说没有任何作用。

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类型。

以上就是《SQL错误:在列索引 6 上扫描“scheduled_date”时出错,无法将 uint8 类型转换为 null.Time》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>