go-sql-driver包 實現mysql不定欄位查詢

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

go-sql-driver包是一個第三方包 下載地址http://github.com/go-sql-driver/mysql 下面直接上代碼

package mainimport ("database/sql""fmt"_ "github.com/go-sql-driver/mysql")func main() {//串連資料庫db, err := sql.Open("mysql", "root:@tcp(localhost:3306)/go?charset=utf8")if err != nil {fmt.Println("串連資料庫失敗", err.Error())return}defer db.Close()//查詢資料庫query, err := db.Query("select * from go_user")if err != nil {fmt.Println("查詢資料庫失敗", err.Error())return}defer query.Close()//讀出查詢出的欄欄位名cols, _ := query.Columns()//values是每個列的值,這裡擷取到byte裡values := make([][]byte, len(cols))//query.Scan的參數,因為每次查詢出來的列是不定長的,用len(cols)定住當次查詢的長度scans := make([]interface{}, len(cols))//讓每一行資料都填充到[][]byte裡面for i := range values {scans[i] = &values[i]}//最後得到的mapresults := make(map[int]map[string]string)i := 0for query.Next() { //迴圈,讓遊標往下推if err := query.Scan(scans...); err != nil { //query.Scan查詢出來的不定長值放到scans[i] = &values[i],也就是每行都放在values裡fmt.Println(err)return}row := make(map[string]string) //每行資料for k, v := range values { //每行資料是放在values裡面,現在把它挪到row裡key := cols[k]row[key] = string(v)}results[i] = row //裝入結果集中i++}//查詢出來的數組for k, v := range results {fmt.Println(k, v)}db.Close() //用完關閉}



註:原創者是 http://www.du52.com/text.php?id=562  我做了注釋,這樣容易看懂點

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.