1. 程式人生 > 資料庫 >在golang中操作mysql資料庫的實現程式碼

在golang中操作mysql資料庫的實現程式碼

前言

Golang 提供了database/sql包用於對SQL資料庫的訪問,作為操作資料庫的入口物件sql.DB,主要為我們提供了兩個重要的功能:

•sql.DB 通過資料庫驅動為我們提供管理底層資料庫連線的開啟和關閉操作.

•sql.DB 為我們管理資料庫連線池

需要注意的是,sql.DB表示操作資料庫的抽象訪問介面,而非一個數據庫連線物件;它可以根據driver開啟關閉資料庫連線,管理連線池。正在使用的連線被標記為繁忙,用完後回到連線池等待下次使用。所以,如果你沒有把連線釋放回連線池,會導致過多連線使系統資源耗盡。

Golang操作mysql簡介

Golang操作mysql資料庫的感覺有點想php中的pdo對mysql操作,假設你原本是phper轉型到golang中的接受起來很親切,總體的感覺非常簡單

Golang操作mysql的注意點

golang實現了對mysql操作的標準庫然而卻沒有實現mysql的驅動

因此我們需要先從github中下載go-sql-driver這個驅動包(建議在src目錄下執行),使用命令如下所示:

go get github.com/go-sql-driver/mysql

在test資料庫中建立表字段如下所示

CREATE TABLE IF NOT EXISTS `test`.`user` (
 `user_id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '使用者編號',`user_name` VARCHAR(45) NOT NULL COMMENT '使用者名稱稱',`user_age` TINYINT(3) UNSIGNED NOT NULL DEFAULT 0 COMMENT '使用者年齡',`user_sex` TINYINT(3) UNSIGNED NOT NULL DEFAULT 0 COMMENT '使用者性別',PRIMARY KEY (`user_id`))
 ENGINE = InnoDB
 AUTO_INCREMENT = 1
 DEFAULT CHARACTER SET = utf8
 COLLATE = utf8_general_ci
 COMMENT = '使用者表'

實現對資料的增(insert)操作

package main
import (
 "fmt"
 "database/sql"
 //匯入mysql的驅動
 _ "github.com/go-sql-driver/mysql" 
)
func main(){
 //使用database/sql包中的Open連線資料庫
 db,err := sql.Open("mysql","root:root@tcp(localhost:3306)/test?charset=utf8")
 if err != nil {
 fmt.Println("連線資料庫失敗:",err)
 return 
 }
 //使用DB結構體例項方法Prepare預處理插入,Prepare會返回一個stmt物件
 stmt,err := db.Prepare("insert into `user`(user_name,user_age,user_sex)values(?,?,?)")
 if err!=nil{
 fmt.Println("預處理失敗:",err)
 return  
 }
 //使用Stmt物件執行預處理引數
 result,err := stmt.Exec("pengjin",33,"男")
 if err!=nil{
 fmt.Println("執行預處理失敗:",err)
 return  
 }else{
 rows,_ := result.RowsAffected()
 fmt.Println("執行成功,影響行數",rows,"行" )
 }
}

如上程式碼有一種操作php中pdo的感覺,如上程式碼實際上也可以不編寫Prepare方法直接通過Stmt例項的Exec方法直接實現

總結

以上所述是小編給大家介紹的在golang中操作mysql資料庫的實現程式碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對我們網站的支援!