golang 下 mongodb 與 postgresql 插入速度的測試

來源:互聯網
上載者:User
這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。

近期看了篇文章,說是postgresql也支援nosql,定義了專屬的jsonb資料類型,而且速度比mongodb還快,今天驗證了下,同樣的資料,postgre的插入速度只是mongo 的三分一不到。有可能是各自的驅動造成的。

 

資料結構:type StockDay struct {    Date             int32    O, H, L, C, V, A float32}mongo 用了mgo 包,插入代碼如下:func ReadHq(conn net.Conn, c *mgo.Collection, Code string) {    var buf [28]byte    var x Stock    var y Kline_Day    for i := 0; ; i++ {        _, err := conn.Read(buf[0:28])        if err == io.EOF {            fmt.Println("此個檔案傳輸結束")            break        }        if err != nil {            fmt.Println(err)            return        }        b_buf := bytes.NewBuffer(buf[0:28])        binary.Read(b_buf, binary.LittleEndian, &x) //binary.LittleEndian  是記憶體中的位元組序的概念,就是把低位元組的放到了後面。網路傳輸一般用BigEndian,記憶體位元組序和cpu有關,編程時要轉化。        y.Code = Code        y.A = x.A        y.C = x.C        y.Date = x.Date        y.H = x.H        y.L = x.L        y.O = x.O        y.V = x.V        //fmt.Println(y)        err = c.Insert(&y)        if err != nil {            panic(err)        }    }    return}#postgresql 的表結構CREATE TABLE json_test(  id serial NOT NULL,  data jsonb,  CONSTRAINT json_test_pkey PRIMARY KEY (id))用了 "github.com/lib/pq" 這個包:插入代碼:func ReadHq(conn net.Conn, db *sql.DB, Code string) {    var buf [28]byte    var x StockDay    for {        _, err := conn.Read(buf[0:28])        if err == io.EOF {            fmt.Println("此個檔案傳輸結束")            break        }        if err != nil {            fmt.Println(err)            return        }        b_buf := bytes.NewBuffer(buf[0:28])        binary.Read(b_buf, binary.LittleEndian, &x) //binary.LittleEndian  是記憶體中的位元組序的概念,就是把低位元組的放到了後面。網路傳輸一般用BigEndian,記憶體位元組序和cpu有關,編程時要轉化。        //fmt.Println(y)        //err = c.Insert(&y)        buf, err := json.Marshal(&x)        //插入資料        stmt, err := db.Prepare("INSERT INTO json_test(data) VALUES($1) RETURNING id")        checkErr(err)        _, err = stmt.Exec(string(buf))        checkErr(err)    }    return}

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.