這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
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 我做了注釋,這樣容易看懂點