登录
首页 >  Golang >  Go问答

如何访问sql.Rows的未转换的driver.Value切片

来源:stackoverflow

时间:2024-04-16 08:42:36 256浏览 收藏

Golang不知道大家是否熟悉?今天我将给大家介绍《如何访问sql.Rows的未转换的driver.Value切片》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

问题内容

我的目标是获取由 sql 驱动程序在 driver.rows.next() 实现中反序列化的原始 driver.value 值。 我想处理从驱动程序返回的值到所需目标类型的转换,而不是依赖于 rows.scan 内置的自动转换。请注意,此问题不会询问您是否对此有意见“应该”使用 rows.scan。我不想使用它,我想问是否有办法避免它。

有意义的答案根本不使用 rows.scan。使用未知列中说明的动态方法非常糟糕:它调用 scan 的所有开销并破坏源列的类型信息,而不是将实际的 driver.values 分解为 sqlbytes

以下 hack 有效,但依赖于内部实现细节,即 sql.rows.next() 使用我想要的未转换值填充内部字段 lastcols

vpRows := reflect.ValueOf(rows)                    // rows is a *sql.Rows
vRows := reflect.Indirect(vpRows)                  // now we have the sql.Rows struct
mem := vRows.FieldByName("lastcols")               // unexported field lastcols
unsafeLastCols := unsafe.Pointer(mem.UnsafeAddr()) // Evil
plastCols := (*[]driver.Value)(unsafeLastCols)     // But effective

for rows.Next() {
    rowVals := *plastCols
    fmt.Println(rowVals)
}

解决方案


正常的解决方案是实现您自己的sql.Scanner。但这确实使用了rows.Scan,因此它违反了您不使用rows.Scan的神秘要求。

如果您确实必须避免 rows.Scan,则需要编写自己的驱动程序实现(可能包装现有驱动程序),以提供对 driver.Value 值的访问,而无需 rows.Scan

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何访问sql.Rows的未转换的driver.Value切片》文章吧,也可关注golang学习网公众号了解相关技术文章。

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