摘要:無法打開和都是,也就是說它們可以指向任意類型,此時是指向結構的指針是具體此時是指針,指向的類型是會把當成對待所有域的信息都會輸出來此時是指向結構的指針只有確定了類型后,才會當成具體類型只有確定了類型后,才會當成具體類型輸出結果如下
package main import ( "gopkg.in/mgo.v2" "log" "reflect" ) func main() { session, err := mgo.Dial("usr:pwd@127.0.0.1:27017/dbname") if err != nil { log.Fatal("無法打開MongoDB!") return } defer session.Close() clt := session.DB("mydb").C("userinfo") type row struct { UserName, Telephone string } var _row, _row2 interface{} // _row和_row2 都是interface,也就是說它們可以指向任意類型,此時是指向row結構的指針 _row = new(row) _row2 = new(row) // _row3 是具體struct _row3 := row{} log.Printf("type of &row: %v ", reflect.TypeOf(&_row)) log.Printf("type of row: %v ", reflect.TypeOf(_row2)) log.Printf("type of &row3: %v ", reflect.TypeOf(&_row3)) it := clt.Find(nil).Limit(1).Iter() log.Println("test unmarshal using", reflect.TypeOf(&_row)) for it.Next(&_row) { // 此時&_row是指針,指向的類型是interface // mongo會把row當成map對待, 所有域的信息都會輸出來 log.Println(_row) } it = clt.Find(nil).Limit(1).Iter() log.Println("test unmarshal using", reflect.TypeOf(_row2)) for it.Next(_row2) { // 此時row2是指向row結構的指針 // 只有確定了類型后,才會當成具體類型 log.Println(_row2) } it = clt.Find(nil).Limit(1).Iter() log.Println("test unmarshal using", reflect.TypeOf(&_row3)) for it.Next(&_row3) { // 只有確定了類型后,才會當成具體類型 log.Println(_row3) } }
輸出結果如下:
2016/04/28 16:23:22 type of &row: *interface {} 2016/04/28 16:23:22 type of row: *main.row 2016/04/28 16:23:22 type of &row3: *main.row 2016/04/28 16:23:22 test unmarshal using *interface {} 2016/04/28 16:23:22 map[_id:ObjectIdHex("5721c757a8917850b210f0ca") username:xiaoming telephone:2222 address:beijing] 2016/04/28 16:23:22 test unmarshal using *main.row 2016/04/28 16:23:22 &{xiaoming 2222} 2016/04/28 16:23:22 test unmarshal using *main.row 2016/04/28 16:23:22 {xiaoming 2222}
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/18839.html
摘要:如果刪除所有用替換其他寫了一個和結合的數據查詢服務細節可點擊鏈接到查看 1.系統環境 Golang:go version go1.10.3 darwin/amd64 OS:MacOS MongoDB: version: 3.4.4 2.Golang使用MongoDB 使用:gopkg.in/mgo.v2 獲取包:go get gopkg.in/mgo.v2 引入:impor...
摘要:搭建服務器采用搭建,可參考讀模式的讀模式共有五種在主節點上進行所有的讀操作優先在主節點上進行讀操作,如果主節點不可用,再從從節點操作。 Replica Sets搭建 服務器采用Replica Sets搭建,可參考Deploy a Replica Set 讀模式 Mongod的讀模式共有五種: primary. 在主節點上進行所有的讀操作 primaryPreferred. 優...
摘要:準備數據結構這個以對一個簡單的通訊錄進行插入查詢更新刪除記錄為例,中包含和兩個字段下載還沒出官方的驅動包,是現在比較流行的第三方包,能找到的相關資料也比較多。準備實現對的增刪改查操作,先想了下怎么寫測試案例。查找,通過查找該條記錄。 環境聲明:go version go1.11MongoDB server version 4.0.3 背景 這是我第一次接觸golang和MongoDB,...
摘要:本節將學習來統一管理和部署微服務,引入第三個微服務并進行存儲數據。到目前為止,要想啟動微服務的容器,均在其中的同時設置其環境變量,服務多了以后管理起來十分麻煩。 譯文鏈接:wuYin/blog原文鏈接:ewanvalentine.io,翻譯已獲作者 Ewan Valentine 授權。 本文完整代碼:GitHub 在上節中,我們使用 go-micro 重新實現了微服務并進行了 Doc...
摘要:實際情況默認情況下,使用自動生成,而且在自帶的命令里,無法指定一個自增字段。自增字段在多線程時必須是原子性的,這在大數據情況下很難實現伸縮性。而且,在里面,有一個命令是原子性的。代碼如下無法打開創建個模擬多線程環境輸出查詢結果 實際情況 默認情況下,mongo使用_id自動生成uniq id,而且在mongo自帶的命令里,無法指定一個自增字段。自增字段在多線程時必須是原子性的,這在大數...
閱讀 3196·2021-11-18 10:02
閱讀 1446·2021-10-12 10:08
閱讀 1239·2021-10-11 10:58
閱讀 1269·2021-10-11 10:57
閱讀 1167·2021-10-08 10:04
閱讀 2121·2021-09-29 09:35
閱讀 773·2021-09-22 15:44
閱讀 1269·2021-09-03 10:30