关于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
的确切输出。
任何人都可以建议我实现这个的正确方法。我认为这是资产共享背景下的常见业务场景,所以请帮助。
提前致谢:)
答案 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。由于在此处使用 富查询 ,因此不存在提交通讯的问题。