記一次couchdb模糊查詢功能
阿新 • • 發佈:2018-12-17
記一次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.thisistest7": {
"$gt": 0
}
}
}
順便記錄一個自己手殘寫的百分比計算的方法:
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)