gpt4 book ai didi

gocql 无法将 blob 解码为 *[20]uint8

转载 作者:IT王子 更新时间:2023-10-29 02:21:04 33 4
gpt4 key购买 nike

我有一个关于使用 blob 类型作为分区键的问题。我使用它,因为我需要保存哈希值。(哈希值返回二进制数据。通常为十六进制。)

我尝试使用 gocql 进行选择查询,但失败并出现以下错误。有什么方法可以让这种查询获得成功的结果吗?

非常感谢您的建议!!

-- 结果哈希值:[208 61 222 22 16 214 223 135 169 6 25 65 44 237 166 229 50 5 40 221]/hash_value: ?=????A,???2(?/哈希值:0xd03dde1610d6df87a90619412ceda6e5320528dd字符串2018/03/22 10:03:17 无法将 blob 解码为 *[20]uint8

-- 选择.go

package main


import (
"fmt"
"log"
"crypto/sha1"
"reflect"
"github.com/gocql/gocql"
)


func main() {
cluster := gocql.NewCluster("10.0.0.1")
cluster.Keyspace = "ks"
cluster.Consistency = gocql.Quorum
cluster.ProtoVersion = 4
cluster.Authenticator = gocql.PasswordAuthenticator{
Username: "cassandra",
Password: "cassandra",
}


session, _ := cluster.CreateSession()
defer session.Close()


text := "text before hashed"
data := []byte(text)
hash_value := sha1.Sum(data)
hexa_string := fmt.Sprintf("0x%x", hash_value)


fmt.Println("hash_value: ", hash_value)
fmt.Println(" / string: ", string(hash_value[:]))
fmt.Println(" / column1: ", hexa_string)
fmt.Println(reflect.TypeOf(hexa_string))


// *** select ***
var column1 int
returned_hash := sha1.Sum(data)


//if err := session.Query(`SELECT hash_value, column1 FROM sample WHERE hash_value= ? LIMIT 1`,
// hexa_string).Consistency(gocql.One).Scan(&returned_hash, &column1); err != nil {
if err := session.Query(`SELECT hash_value, column1 FROM sample WHERE hash_value=0xd03dde1610d6df87a90619412ceda6e5320528dd`).Consistency(gocql.One).Scan(&returned_hash, &column1); err != nil {
//fmt.Println(err)
log.Fatal(err)
}
fmt.Println("comment: ", returned_hash, user_id)


}

-- 表定义--

CREATE TABLE IF NOT EXISTS ks.samle (
hash_value blob,
column1 int,
...
PRIMARY KEY((hash_value), column1)
) WITH CLUSTERING ORDER BY (column1 DESC);

最佳答案

我通过更改变量类型解决了这个问题:returned_hash。

  • returned_hash(存储返回结果的变量)应该是[]byte。

我的理解如下。

  • marshal:将代码中给出的数据转换为cassandra可以处理的类型。
  • 解码:将 cassandra 返回的数据转换回 golang 代码可以处理的类型。
  • 原始错误意味着后一种模式运行不正常。所以 returned_hash 的类型一定是错误的。

如果我错了请纠正我。谢谢。

package main

import (
"fmt"
"log"
"crypto/sha1"
"reflect"
"github.com/gocql/gocql"
)

func main() {
cluster := gocql.NewCluster("127.0.0.1")
cluster.Keyspace = "browser"
cluster.Consistency = gocql.Quorum
//cluster.ProtoVersion = 4
//cluster.Authenticator = gocql.PasswordAuthenticator{
// Username: "cassandra",
// Password: "cassandra",
//}

session, _ := cluster.CreateSession()
defer session.Close()

text := "text before hashed"
data := []byte(text)
hash_value := sha1.Sum(data)
hexa_string := fmt.Sprintf("0x%x", hash_value)

fmt.Println("hash_value: ", hash_value)
fmt.Println(" / string(hash_value): ", string(hash_value[:]))
fmt.Println(" / hexa(hash_value): ", hexa_string)
fmt.Println(reflect.TypeOf(hexa_string))

// *** select ***
var column1 int
//returned_hash := sha1.Sum(data)
//var returned_hash *[20]uint8
var returned_hash []byte

if err := session.Query(`SELECT hash_value, column1 FROM sample WHERE hash_value=? LIMIT 1`,
hash_value[:]).Consistency(gocql.One).Scan(&returned_hash, &column1); err != nil {
//if err := session.Query(`SELECT hash_value, column1 FROM sample WHERE hash_value=0xd03dde1610d6df87a90619412ceda6e5320528dd`).Consistency(gocql.One).Scan(&returned_hash, &column1); err != nil {
log.Fatal(err)
}
fmt.Printf("Returned: %#x %d \n", returned_hash, column1)

}

关于gocql 无法将 blob 解码为 *[20]uint8,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49443823/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com