Hyperledger Fabric V1.0中日期范围的复合键构造

时间:2017-08-21 13:42:22

标签: go blockchain hyperledger hyperledger-fabric

关于this问题,我也有疑问。
假设我的复合键由字段Owner_id~dateOfcreation组成 我的钥匙就像:

  
      
  • Owner1〜2017年11月5日
  •   
  • Owner1〜2017年12月5日
  •   
  • Owner1〜13-05-2017
  •   
  • ...
  •   
  • ...
  •   
  • Owner1〜30-05-2017
  •   

我是否可以获取 date range 的状态,例如Owner1~12-05-2017 to Owner~27-05-2017

在我的理解中,stub.GetStateByRange(startKey,endKey)将返回词汇顺序的键,因此它不会返回预期的范围。 如果我错了,请纠正我。

我试图重新安排像:

这样的键
  
      
  • Owner1〜2017_05_11
  •   
  • Owner1〜2017_05_12
  •   
  • Owner1〜2017_05_13
  •   
  • ...
  •   
  • ...
  •   
  • Owner1〜2017_05_30
  •   

在这种情况下,如果我使用  
stub.GetStateByPartialCompositeKey('owner~year~month~day',[]string{"owner1","2017","05"})它将返回以这些范围开头的所有键。这是对的吗?

但是在这里我也没有得到 date range 的确切输出。

任何人都可以建议我实现这个的正确方法。我认为这是资产共享背景下的常见业务场景,所以请帮助。

提前致谢:)

2 个答案:

答案 0 :(得分:1)

在重新阅读您的问题和评论后,我认为您有自己的解决方案。那么使用GetStateByRange函数呢?此函数不返回键,它返回带有值的迭代器。

正如您在上次评论中所说,我想列出在日期范围内创建的所有资产,我将如何从分类帐查询。所以,如果我是你,我会使用GetStateByRange函数,将日期范围传递给它。

在这里,我粘贴了一个我使用的函数示例。

func get_all_components(stub shim.ChaincodeStubInterface, args []string) pb.Response {
    var err error
    fmt.Println("starting get_all_components")

    // input sanitation
    err = sanitize_arguments_len(args, 1)
    if err != nil {
        return shim.Error(err.Error())
    }

    // ---- Get All Components ---- //
    resultsIterator, err := stub.GetStateByRange("c0", "c9999999999999999999")
    if err != nil {
        return shim.Error(err.Error())
    }
    defer resultsIterator.Close()

    // buffer is a JSON array containing QueryRecords
    var buffer bytes.Buffer
    buffer.WriteString("[")

    bArrayMemberAlreadyWritten := false
    for resultsIterator.HasNext() {
        //queryKeyAsStr, queryValAsBytes, err := resultsIterator.Next()
        queryResponse, err := resultsIterator.Next()
        if err != nil {
            return shim.Error(err.Error())
        }

        // Add a comma before array members, suppress it for the first array member
        if bArrayMemberAlreadyWritten == true {
            buffer.WriteString(",")
        }
        buffer.WriteString("{\"Key\":")
        buffer.WriteString("\"")
        buffer.WriteString(queryResponse.Key)
        buffer.WriteString("\"")

        buffer.WriteString(", \"Record\":")
        // Record is a JSON object, so we write as-is
        buffer.WriteString(string(queryResponse.Value))
        buffer.WriteString("}")
        bArrayMemberAlreadyWritten = true
    }
    buffer.WriteString("]")

    fmt.Printf("get_all_components:\n%s\n", buffer.String())

    return shim.Success(buffer.Bytes())
}

您应该在函数调用中的args中传递 date range 值。

答案 1 :(得分:0)

与现有评论,采用的解决方案和API规范一样,可以得出结论,stub.GetStateByPartialCompositeKey最适合此要求的API。
要仅获取一天的数据,如果使用 CouchDB 富查询 和json date_field:value >作为其状态db。由于在此处使用 富查询 ,因此不存在提交通讯的问题。