我正在使用客户查询进行一些报告。为此,我必须从相应节点的数据库中获取数据。但是,不知道如何做到这一点。通常无论节点如何都可以获取所有数据。
答案 0 :(得分:1)
让我们根据IOU CorDapp(https://github.com/corda/cordapp-example/)做一个例子。有几种方法可以做到这一点:
<强> 1。通过API端点
此端点将返回存储在节点上的任何IOU,其值高于minValue
:
@GET
@Path("ious-above-value")
@Produces(MediaType.APPLICATION_JSON)
fun getIOUsAboveValue(@QueryParam("minValue") minValue: Int): List<IOUState> {
val results = builder {
val currencyIndex = IOUSchemaV1.PersistentIOU::value.greaterThan(minValue)
val customCriteria = QueryCriteria.VaultCustomQueryCriteria(currencyIndex)
rpcOps.vaultQueryBy<IOUState>(customCriteria)
}
val stateAndRefs = results.states
return stateAndRefs.map { stateAndRef -> stateAndRef.state.data }
}
<强> 2。通过客户
此客户端将返回存储在节点上的任何IOU,其值高于minValue
:
fun main(args: Array<String>) {
require(args.size == 1) { "Usage: ExampleClientRPC <node address>" }
val nodeAddress = NetworkHostAndPort.parse(args[0])
val client = CordaRPCClient(nodeAddress)
// Can be amended in the com.example.MainKt file.
val proxy = client.start("user1", "test").proxy
val results = builder {
val currencyIndex = IOUSchemaV1.PersistentIOU::value.greaterThan(3)
val customCriteria = QueryCriteria.VaultCustomQueryCriteria(currencyIndex)
proxy.vaultQueryBy<IOUState>(customCriteria)
}
val stateAndRefs = results.states
val states = stateAndRefs.map { stateAndRef -> stateAndRef.state.data }
}
第3。直接通过节点的数据库
您可以按照此处的说明登录节点的数据库:https://docs.corda.net/node-database.html。然后,您就可以直接对节点的数据库执行SQL查询。