1. 程式人生 > >記一次couchdb模糊查詢功能

記一次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.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)