這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
產生objectid
i := bson.NewObjectId()c.Insert(bson.M{"_id": i, "foo": "bar"})
golang 使用 mongo gte lte 功能
searchErr = SearchReading(bson.M{"k": key, "t": bson.M{"$gte": start, "$lte": end}}, limit)
不能直接寫
searchErr = SearchReading(bson.M{"k": key, "t":'{"$gte": start, "$lte": end}'}, limit)
基礎小工具
golang md5 計算
func genQueryMd5(str string) string {
hash := md5.New()
b := []byte(str)
hash.Write(b)
hash.Sum(nil)
return fmt.Sprintf("%x", md5.Sum(b))
}
- When you call Sum(nil) it returns d.checkSum() directly as a byte slice, however if you call Sum([]byte) it appends d.checkSum() to your input.
- Write函數會把MD5對象內部的字串clear掉,然後把其參數作為新的內部字串。而Sum函數則是先計算出內部字串的MD5值,而後把輸入參數附加到內部字串後面。即可以為認為:hash.Write(b) + hash.Sum(nil) = hash.Write(nil) + hash.Sum(b) + hash.Sum(nil) = md5.Sum(b)。
解析字串為 int64
func ParseInt(s string, base int, bitSize int) (i int64, err error)
參數1 數位字串形式
參數2 數字字串的進位 比如二進位 八進位 十進位 十六進位
參數3 返回結果的bit大小 也就是int8 int16 int32 int64
import
( "strconv")
i, err := strconv.ParseInt("123", 10, 32)
時間戳記互換
擷取時間戳記用time.Now().Unix(),格式化時間用t.Format,解析時間用time.Parse
timestamp := time.Now().Unix()
//格式化為字串,tm為Time類型tm := time.Unix(timestamp, 0)fmt.Println(tm.Format("2006-01-02 03:04:05"))
//從字串轉為時間戳記,第一個參數是格式,第二個是要轉換的時間字串tm2, _ := time.Parse("01/02/2006", "02/08/2015")
golang byte 轉string
golang裡邊 string的概念其實不是以前遇到/0結尾的概念了,他其實就是一塊連續的記憶體,首地址+長度,上面那樣賦值,如果p裡邊有/0,他不會做處理這個時候,如果再對這個string做其他處理就可能出問題了,比如strconv.Atoi轉成int就有錯誤,解決辦法就是需要自己寫一個正規的轉換函式:
func byteString(p []byte) string {
for i := 0; i < len(p); i++ {
if p[i] == 0 {
return string(p[0:i])
}
}
return string(p)
}
golang Polymorphism的支援。interface對多態的支援還是比較有限。down casting做不了有的時候還是不大方便。用父類做方法參數,傳遞子類則會編譯失敗,無法做通用類