在golang中操作mysql數(shù)據(jù)庫的實(shí)現(xiàn)代碼
Golang 提供了database/sql包用于對SQL數(shù)據(jù)庫的訪問, 作為操作數(shù)據(jù)庫的入口對象sql.DB, 主要為我們提供了兩個(gè)重要的功能:
•sql.DB 通過數(shù)據(jù)庫驅(qū)動為我們提供管理底層數(shù)據(jù)庫連接的打開和關(guān)閉操作.
•sql.DB 為我們管理數(shù)據(jù)庫連接池
需要注意的是,sql.DB表示操作數(shù)據(jù)庫的抽象訪問接口,而非一個(gè)數(shù)據(jù)庫連接對象;它可以根據(jù)driver打開關(guān)閉數(shù)據(jù)庫連接,管理連接池。正在使用的連接被標(biāo)記為繁忙,用完后回到連接池等待下次使用。所以,如果你沒有把連接釋放回連接池,會導(dǎo)致過多連接使系統(tǒng)資源耗盡。
Golang操作mysql簡介
Golang操作mysql數(shù)據(jù)庫的感覺有點(diǎn)想php中的pdo對mysql操作,假設(shè)你原本是phper轉(zhuǎn)型到golang中的接受起來很親切,總體的感覺非常簡單
Golang操作mysql的注意點(diǎn)
golang實(shí)現(xiàn)了對mysql操作的標(biāo)準(zhǔn)庫然而卻沒有實(shí)現(xiàn)mysql的驅(qū)動
因此我們需要先從github中下載go-sql-driver這個(gè)驅(qū)動包(建議在src目錄下執(zhí)行),使用命令如下所示:
go get github.com/go-sql-driver/mysql
在test數(shù)據(jù)庫中建立表字段如下所示
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 = '用戶表'
實(shí)現(xiàn)對數(shù)據(jù)的增(insert)操作
package main
import (
"fmt"
"database/sql"
//導(dǎo)入mysql的驅(qū)動
_ "github.com/go-sql-driver/mysql"
)
func main(){
//使用database/sql包中的Open連接數(shù)據(jù)庫
db,err := sql.Open("mysql","root:root@tcp(localhost:3306)/test?charset=utf8")
if err != nil {
fmt.Println("連接數(shù)據(jù)庫失敗:",err)
return
}
//使用DB結(jié)構(gòu)體實(shí)例方法Prepare預(yù)處理插入,Prepare會返回一個(gè)stmt對象
stmt,err := db.Prepare("insert into `user`(user_name,user_age,user_sex)values(?,?,?)")
if err!=nil{
fmt.Println("預(yù)處理失敗:",err)
return
}
//使用Stmt對象執(zhí)行預(yù)處理參數(shù)
result,err := stmt.Exec("pengjin",33,"男")
if err!=nil{
fmt.Println("執(zhí)行預(yù)處理失敗:",err)
return
}else{
rows,_ := result.RowsAffected()
fmt.Println("執(zhí)行成功,影響行數(shù)",rows,"行" )
}
}
如上代碼有一種操作php中pdo的感覺 ,如上代碼實(shí)際上也可以不編寫Prepare方法直接通過Stmt實(shí)例的Exec方法直接實(shí)現(xiàn)
總結(jié)
以上所述是小編給大家介紹的在golang中操作mysql數(shù)據(jù)庫的實(shí)現(xiàn)代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對本站網(wǎng)站的支持!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信