8. Fabric2.2 区块链农产品溯源系统 - 智能合约设计

根据上小节的需求分析与方案设计来进行智能合约的设计。

智能合约设计最核心的是存储字段的设计、也就是索引设计,Fabric 常见的时间状态存储引擎是LevelDB 或 CouchDB,这两个数据库是KV存储,KV存储不像SQL类型存储,一张表创建多个字段,多个字段索引可以进行各种复查询,KV存储及查询比较简单,仅仅存储两个字段Key与Value,为什么会采用KV存储,因为Fabric设计考虑MVCC 多版本并发控制,所以采用KV结构容易标记Version。

1.智能合约数据存取

1.)普通数据插入与查询,操作简单

插入API:PutState(Key, Value)
插入:Key:张三 Value:100元
PutState(“张三”,“100元”)

查询API:GetState(Key)
查询: Key:张三
返回:Value:100元
GetState(“张三”)

2)范围查询
范围查询的场景比较常见,例如根据时间范围查找某些数据,对于KV数据库如何实现范围查询呢。Fabric提供范围查询API GetStateByRange(startKey, endKey),查询从startKey(闭区间) 到 endKey(开区间)的全部数据。

例如:系统记录张三的多个行为
PutState(“张三#1”,“吃饭”)
PutState(“张三#2”,“睡觉”)
PutState(“张三#3”,“打豆豆”)

范围查询 张三的所有行为
GetStateByRange(“张三#0”

猜你喜欢

转载自blog.csdn.net/xjmtxwd24/article/details/123126863