您好,登錄后才能下訂單哦!
這篇文章主要為大家詳細(xì)介紹了go操作mysql數(shù)據(jù)庫的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
Go(又稱Golang)是Google開發(fā)的一種靜態(tài)強(qiáng)類型、編譯型、并發(fā)型,并具有垃圾回收功能的編程語言。下面就來由go入門教程欄目介紹一些關(guān)于mysql的操作。
go操作mysql數(shù)據(jù)庫,用的庫是 go-sql-driver/mysql,安裝直接go get
go get -u github.com/go-sql-driver/mysql
sql.DB
DB類型可用的函數(shù)有:
1、Query(c string, args interface{} …) (*Rows, error),常用于SELECT語句
2、Exec(c string, args interface{} …) (*Rows, error),常用與UPDATE和INSERT
3、Prepare(c string) (*Stmt, error),其他語句,也可以用于執(zhí)行上述語句,返回Stmt指針
sql.Stmt
Stmt是準(zhǔn)備好的語句,可以執(zhí)行數(shù)據(jù)庫語句操作,常用函數(shù)有:
Exec(args interface{} …) (Result, error),給定參數(shù)并執(zhí)行準(zhǔn)備好的語句,然后返回語句的總結(jié)果
//... stmt, err := db.Perpare("INSERT INTO User(user,pwd) VALUES (?, ?)") if err != nil { panic(err) } defer stmt.Close() _, err := stmt.Exec("laoli", "123456") if err != nil { panic(err) } //... //... stmt, err := db.Perpare("DELETE FROM User") if err != nil { panic(err) } defer stmt.Close() _, err := stmt.Exec() if err != nil { panic(err) }
Query(args interface{} …) (*Rows, error),給定參數(shù)并執(zhí)行準(zhǔn)備好的語句,返回行結(jié)果,比方說SELECT操作就必須用這個(gè)函數(shù)調(diào)用。
sql.Rows
Rows是sql語句執(zhí)行返回的表,Rows會(huì)占用緩存,Rows.Next()里,如果返回false,則會(huì)自動(dòng)釋放緩存。
看一下源碼:
// 源碼 func (rs *Rows) Next() bool { var doClose, ok bool withLock(rs.closemu.RLocker(), func() { doClose, ok = rs.nextLocked() }) if doClose { rs.Close() //在這里釋放掉了 } return ok }
例子:
package main import ( "database/sql" _ "github.com/go-sql-driver/mysql" ) var db *sql.DB func mian() { db = sql.Open("mysql", "root:123456@tcp(127.0.0.1)/test") if err := db.Ping(); err != nil { panic(err) } } func Insert() { _, err := db.Exec("INSERT INTO User(user, pwd) VALUE (?, ?)", "laowang", "123456") if err != nil { panic(err) } } func SelectRow() { rows, err := db.Query("SELECT * FROM User WHERE user=?", "laowang") if err != nil { panic(err) } //defer rows.Close() //如果后面代碼沒有循環(huán)調(diào)用rows.Next(),就需要手動(dòng)在這里釋放一下,不然會(huì)一直占用緩存 var user string var pwd string for rows.Next() { row.Scan(&user, &pwd) } print(user, pwd) }
關(guān)于go操作mysql數(shù)據(jù)庫的方法就分享到這里了,當(dāng)然并不止以上和大家分析的辦法,不過小編可以保證其準(zhǔn)確性是絕對沒問題的。希望以上內(nèi)容可以對大家有一定的參考價(jià)值,可以學(xué)以致用。如果喜歡本篇文章,不妨把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。