couchdb
记一次couchdb模糊查询
在使用fabric的过程中,避免不了使用couchdb,记录一次模糊匹配的使用记录,方便下次查找。
在couchdb中存的数据结构:
type Account struct {
Addr string `json:"addr"` // 地址
Balance map[string]*big.Int `json:"balance"` // 余额(各种账本不同的余额)
Nonce int `json:"nonce"` // 交易序号
IsToken bool `json:"isToken"` // 其它业务标识
}
需求:获取拥有指定账本的所有账户的地址、余额、以及所占总量的百分比
技术点:匹配map类型的时候,需要使用 字段.key
匹配语法:
{
"selector": {
"balance.test7": {
"$gt": 0
}
}
}
记一次couchdb中$nor 使用示例
{
"selector": {
"$nor": [
{
"id": "preTransAccount"
},
{
"id": "19ABC21B927337099A17ED7A06FC406BF1B7FDDF"
}
]
},
"sort": [
{
"balance": "desc"
}
]
}
使用正则匹配
需求:要求匹配出type字段以test开头的数据项
{
"selector": {
"type": {
"$regex": "test*"
}
}
}
顺便记录一个自己手残写的百分比计算的方法:
var zero = new(big.Int).SetInt64(1000000000000000000)
// 保留4位小数,百分比之后变成2位
var percentSuf = new(big.Int).SetInt64(10000)
func toPercent(per string) string {
len := len(per)
var s string
if len == 2 {
s = "0" + string([]byte(per)[:len-2]) + "." + string([]byte(per)[len-2:]) + "%"
} else if len == 1 {
s = "0.0" + string([]byte(per)[len-1:]) + "%"
} else {
s = string([]byte(per)[:len-2]) + "." + string([]byte(per)[len-2:]) + "%"
}
return s
}
(方法就是在做除法前先将分子扩大,然后将结果缩小至保留4位小数,将结果在添加小数点和百分号)
// test
zero := new(big.Int).SetInt64(1000000000000000000)
a := new(big.Int).SetInt64(10000)
fmt.println(a.String())
b := new(big.Int).Mul(new(big.Int).SetInt64(9999), zero)
fmt.Println(b.String())
c := new(big.Int).Div(b, a)
fmt.Println(c.String())
res := c.Div(c, zero.Div(zero, new(big.Int).SetInt64(10000)))
fmt.Println(res.String())
percent := toPercent(res.String())
fmt.Println(percent)
文章最后发布于: 2018-10-25 19:57:24
相关阅读
A5创业网(公众号:iadmin5)11月29日消息:近期,有消息称,携号转网业务将在11月26日到11月30日暂停,12月1日启用新的办理流程。据悉,这一改
https://www.blitzstars.com
方法1: 方法2:
A5创业网(公众号:iadmin5)7月25日报道,近日途牛内部员工爆料称,途牛目前针对本部门(国内客服部)降薪,单方面给客服降低提成点,由原来4.5%的
天猫是淘宝平台中一个很火的平台,因为它的入驻门槛很高,需要的保证金很多,所以一般的小商户是没有资格入驻的,这也说明天猫店商品的质