前言
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數據庫的實現代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
您可能感興趣的文章:- Golang操作MySql數據庫的完整步驟記錄
- 如何利用Golang解析讀取Mysql備份文件
- Golang中如何對MySQL進行操作詳解
- golang gorm 操作mysql及gorm基本用法
- golang實現mysql數據庫備份的操作方法
- golang中連接mysql數據庫