登录
首页 >  Golang >  Go问答

shim.GetStateByPartialCompositeKey 迭代器在此代码中如何工作?

来源:stackoverflow

时间:2024-04-10 14:09:34 210浏览 收藏

Golang不知道大家是否熟悉?今天我将给大家介绍《shim.GetStateByPartialCompositeKey 迭代器在此代码中如何工作?》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

问题内容

我正在编写链码,其中将一些数据放入分类帐中,然后尝试使用 shim.getstatebypartialcompositekey() 列出它,其中我从迭代器获取数据列表。现在我想根据时间戳对数据进行排序(仅按日期格式化,而不需要小时、分钟或秒)。所以,我想知道我从迭代器列出的数据是否按照存储在分类帐中的时间戳排序,或者我是否需要对它们进行排序?!

var AvalList = make([]A, 0)
iterator, err := stub.GetStateByPartialCompositeKey("AId~BId", []string{AId})
    if err != nil {
        fmt.Println("error is ", err)
        return shim.Error(err.Error())
    }
    fmt.Println("Iterator is ", iterator)
    if !iterator.HasNext() {
        fmt.Println("---------------------  Iterator not found!!!  --------------------")
        return shim.Error(err.Error())
    }
    defer iterator.Close()

    for i := 0; iterator.HasNext(); i++ {
        ARange, err := iterator.Next()
        if err != nil {
            return shim.Error(err.Error())
        }

        objectType, compositeKeyParts, err := stub.SplitCompositeKey(ARange.Key)
        if err != nil {
            return shim.Error(err.Error())
        }

        returnedA := compositeKeyParts[1]
        fmt.Printf("Found a A of index %s and id %s ", objectType, returnedA)

        ABytes, err := stub.GetState(returnedA)
        if err != nil {
            return shim.Error(err.Error())
        }
        if ABytes == nil {
            fmt.Println("A not found")
            return shim.Error("Entity not found")
        }


        a := A{}
        err = json.Unmarshal(ABytes, &a)
        if err != nil {
            return shim.Error("Failed to unmarshal")
        }

            AvalList = append(AvalList, a)
    }

解决方案


GetStateByPartialCompositeKey 根据给定的部分组合键查询账本中的状态。此函数返回一个迭代器,可用于迭代其前缀与给定的部分复合键匹配的复合键。

阅读https://github.com/hyperledger/fabric-chaincode-go/blob/master/shim/interfaces.go

现在,根据问题,

我从迭代器列出的数据按时间戳排序

没有。它不会按排序顺序。例如,如果您正在查询大量数据 那么迭代器将获得所有组合键,这些组合键不一定按排序顺序排列。因此你必须对它们进行排序。

执行此操作的方法之一是使用 sort.Sort() 函数。 这里提出了类似的方法How to sort by time.Time

到这里,我们也就讲完了《shim.GetStateByPartialCompositeKey 迭代器在此代码中如何工作?》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

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