91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Golang如何連接MySQL數據庫

發布時間:2021-07-20 18:21:29 來源:億速云 閱讀:447 作者:chen 欄目:數據庫

本篇內容主要講解“Golang如何連接MySQL數據庫”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Golang如何連接MySQL數據庫”吧!

Go原生就支持連接數據庫,所以在使用 Golang 開發時,當需要數據庫交互時,即可使用database/sql包。

Golang如何連接MySQL數據庫

在Go中訪問DB需用sql.DB接口:可創建語句(statement)和事務(transaction),執行查詢,獲取結果。

使用DB時,除database/sql包,還需引入想使用的特定DB驅動。官方不提供實現,需要先下載三方實現,點擊這里查看各種各樣的實現版本。

通常DB選型MySQL,所以選型驅動為:github.com/go-sql-driver/mysql,需引入包:

"database/sql"_ "github.com/go-sql-driver/mysql"

包名前的"_"

import 下劃線(如:import _  github/demo)的作用:當導入一個包時,該包下的文件里所有init()函數都會被執行,然而,有些時候我們并不需要把整個包都導入進來,僅僅是是希望它執行init()函數而已。這個時候就可以使用  import _ 引用該包。

上面的MySQL驅動中引入的就是MySQL包中各個init()方法,你無法通過包名來調用包中的其他函數。導入時,驅動的初始化函數會調用sql.Register將自己注冊在database/sql包的全局變量sql.drivers中,以便以后通過sql.Open訪問。

Golang如何連接MySQL數據庫

案例用數據表

Golang如何連接MySQL數據庫

初始化數據庫連接Golang如何連接MySQL數據庫

Golang如何連接MySQL數據庫

sql.Open()中的數據庫連接串格式為:"用戶名:密碼@tcp(IP:端口)/數據庫?charset=utf8"。DB的類型為:*sql.DB,有DB后即可執行CRUD。

Go將數據庫操作分為兩類:Query與Exec

  • Query表示查詢,它會從數據庫獲取查詢結果(一系列行,可能為空)。

  • Exec表示執行語句,它不會返回行。

常見數據庫操作模式:

  • QueryRow只返回一行的查詢,作為Query的一個常見特例。

  • Prepare準備一個需要多次使用的語句,供后續執行用。

查詢操作

var user User rows, e := DB.Query("select * from user where id in (1,2,3)") if e == nil {     errors.New("query incur error") } for rows.Next(){     e := rows.Scan(user.sex, user.phone, user.name, user.id,        user.age)     if e != nil{         fmt.Println(json.Marshal(user))     } } rows.Close() // 單行查詢操作 DB.QueryRow("select * from user where id=1").Scan(user.age,    user.id, user.name, user.phone, user.sex)

執行流程

  1. 鴻蒙官方戰略合作共建——HarmonyOS技術社區

  2. 使用db.Query()來發送查詢到數據庫,獲取結果集Rows,并檢查錯誤。

  3. 使用rows.Next()作為循環條件,迭代讀取結果集。

  4. 使用rows.Scan從結果集中獲取一行結果。

  5. 使用rows.Err()在退出迭代后檢查錯誤。

  6. 使用rows.Close()關閉結果集,釋放連接。

增刪改和Exec

通常不會約束你查詢必須用Query,只是Query會返回結果集,而Exec不會返回。所以如果你執行的是增刪改操作一般用Exec會好一些。Exec返回的結果是Result,Result接口允許獲取執行結果的元數據:

type Result interface {     // 用于返回自增ID,并不是所有的關系型數據庫都有這個功能。     LastInsertId() (int64, error)     // 返回受影響的行數。     RowsAffected() (int64, error) }

準備查詢

如果你現在想使用占位符的功能,where  的條件想以參數的形式傳入,Go提供了db.Prepare語句來幫你綁定。準備查詢的結果是一個準備好的語句(prepared  statement),語句中可以包含執行時所需參數的占位符(即綁定值)。準備查詢比拼字符串的方式好很多,它可以轉義參數,避免SQL注入。同時,準備查詢對于一些數據庫也省去了解析和生成執行計劃的開銷,有利于性能。

占位符

PostgreSQL使用$N作為占位符,N是一個從1開始遞增的整數,代表參數的位置,方便參數的重復使用。MySQL使用?作為占位符,SQLite兩種占位符都可以,而Oracle則使用:param1的形式。

MySQL               PostgreSQL            Oracle =====               ==========            ====== WHERE col = ?       WHERE col = $1        WHERE col = :col VALUES(?, ?, ?)     VALUES($1, $2, $3)    VALUES(:val1, :val2, :val3) stmt, e := DB.Prepare("select * from user where id=?") query, e := stmt.Query(1) query.Scan()

 事務的使用

通過db.Begin()來開啟一個事務,Begin方法會返回一個事務對象Tx。在結果變量Tx上調用Commit()或者Rollback()方法會提交或回滾變更,并關閉事務。在底層,Tx會從連接池中獲得一個連接并在事務過程中保持對它的獨占。事務對象Tx上的方法與數據庫對象sql.DB的方法一一對應,例如Query,Exec等。事務對象也可以準備(prepare)查詢,由事務創建的準備語句會顯式綁定到創建它的事務。

//開啟事務 tx, err := DB.Begin() if err != nil {     fmt.Println("tx fail") } //準備sql語句 stmt, err := tx.Prepare("DELETE FROM user WHERE id = ?") if err != nil {     fmt.Println("Prepare fail")     return false } //設置參數以及執行sql語句 res, err := stmt.Exec(user.id) if err != nil {     fmt.Println("Exec fail")     return false } //提交事務 tx.Commit()  我們來一個完整的sql操作:package main  import (     "database/sql"     "encoding/json"     "fmt"     _ "github.com/go-sql-driver/mysql"     "github.com/pkg/errors"     "strings" )  //數據庫配置 const (     userName = "root"     password = "123456"     ip       = "127.0.0.1"     port     = "3306"     dbName   = "test" )  //Db數據庫連接池 var DB *sql.DB  type User struct {     id    int64     name  string     age   int8     sex   int8     phone string }  //注意方法名大寫,就是public func InitDB() {     //構建連接:"用戶名:密碼@tcp(IP:端口)/數據庫?charset=utf8"     path := strings.Join([]string{userName, ":", password, "@tcp(", ip, ":", port, ")/", dbName, "?charset=utf8"}, "")     //打開數據庫,前者是驅動名,所以要導入:_ "github.com/go-sql-driver/mysql"     DB, _ = sql.Open("mysql", path)     //設置數據庫最大連接數     DB.SetConnMaxLifetime(100)     //設置上數據庫最大閑置連接數     DB.SetMaxIdleConns(10)     //驗證連接     if err := DB.Ping(); err != nil {         fmt.Println("open database fail")         return     }     fmt.Println("connnect success") }  //查詢操作 func Query() {     var user User     rows, e := DB.Query("select * from user where id in (1,2,3)")     if e == nil {         errors.New("query incur error")     }     for rows.Next() {         e := rows.Scan(user.sex, user.phone, user.name, user.id, user.age)         if e != nil {             fmt.Println(json.Marshal(user))         }     }     rows.Close()     DB.QueryRow("select * from user where id=1").Scan(user.age, user.id, user.name, user.phone, user.sex)      stmt, e := DB.Prepare("select * from user where id=?")     query, e := stmt.Query(1)     query.Scan() }  func DeleteUser(user User) bool {     //開啟事務     tx, err := DB.Begin()     if err != nil {         fmt.Println("tx fail")     }     //準備sql語句     stmt, err := tx.Prepare("DELETE FROM user WHERE id = ?")     if err != nil {         fmt.Println("Prepare fail")         return false     }     //設置參數以及執行sql語句     res, err := stmt.Exec(user.id)     if err != nil {         fmt.Println("Exec fail")         return false     }     //提交事務     tx.Commit()     //獲得上一個insert的id     fmt.Println(res.LastInsertId())     return true }  func InsertUser(user User) bool {     //開啟事務     tx, err := DB.Begin()     if err != nil {         fmt.Println("tx fail")         return false     }     //準備sql語句     stmt, err := tx.Prepare("INSERT INTO user (`name`, `phone`) VALUES (?, ?)")     if err != nil {         fmt.Println("Prepare fail")         return false     }     //將參數傳遞到sql語句中并且執行     res, err := stmt.Exec(user.name, user.phone)     if err != nil {         fmt.Println("Exec fail")         return false     }     //將事務提交     tx.Commit()     //獲得上一個插入自增的id     fmt.Println(res.LastInsertId())     return true }  func main() {     InitDB()     Query()     defer DB.Close() }

到此,相信大家對“Golang如何連接MySQL數據庫”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宁武县| 伊通| 平利县| 错那县| 繁峙县| 偏关县| 吉林省| 永州市| 耒阳市| 贺州市| 旌德县| 常山县| 肃北| 吉安市| 赞皇县| 杂多县| 禹州市| 河曲县| 昌图县| 丹棱县| SHOW| 虞城县| 河北区| 隆尧县| 普陀区| 兴文县| 松潘县| 海晏县| 新平| 新疆| 吴堡县| 台北市| 秦皇岛市| 依安县| 临颍县| 汤原县| 锦州市| 长兴县| 玛曲县| 泸溪县| 调兵山市|