2022-09-10 Go語言連接使用MySQL

1.新建一個數(shù)據(jù)庫名hui,數(shù)據(jù)庫表名roles表結(jié)構(gòu)如下圖:

image.png

其中avatar字段保存的是二進制數(shù)據(jù)柠辞。
2.創(chuàng)建與表結(jié)構(gòu)映射的結(jié)構(gòu)體,方便存儲讀取數(shù)據(jù)。
3.具體簡單示例如下代碼:

package main

//Go語言中的database/sql包提供了保證SQL或類SQL數(shù)據(jù)庫的泛用接口菲嘴,并不提供具體的數(shù)據(jù)庫驅(qū)動。
//使用database/sql包時必須注入(至少)一個數(shù)據(jù)庫驅(qū)動汰翠。
import (
    "fmt"
    "io/ioutil"
    "log"
    "database/sql"                                 //接口
    _ "github.com/go-sql-driver/mysql" //MySQL驅(qū)動
)

//其中sql.DB是表示連接的數(shù)據(jù)庫對象(結(jié)構(gòu)體實例)龄坪,它保存了連接數(shù)據(jù)庫相關(guān)的所有信息。
//它內(nèi)部維護著一個具有零到多個底層連接的連接池复唤,它可以安全地被多個goroutine同時使用健田。
// 定義一個全局對象db
var db *sql.DB

func initDB() (err error) {
    //事實上這個數(shù)據(jù)庫中并不存在這個student庫,但是Open沒有返回err
    //Open函數(shù)可能只是驗證其參數(shù)格式是否正確,實際上并不創(chuàng)建與數(shù)據(jù)庫的連接佛纫。
    dsn := "root:root123456@tcp(127.0.0.1:3306)/hui"
    db, err = sql.Open("mysql", dsn)
    if err != nil {
        return err
    }
    // 嘗試與數(shù)據(jù)庫建立連接(校驗dsn是否正確)
    err = db.Ping()
    if err != nil {
        return err
    }
    //設(shè)置數(shù)據(jù)庫連接池的最大連接數(shù)
    db.SetMaxOpenConns(4)
    //設(shè)置數(shù)據(jù)庫連接池的最大空閑連接數(shù)
    db.SetMaxIdleConns(4)
    return nil
}

//表映射結(jié)構(gòu)
type Role struct {
    Role_id   int32
    Role_name string
    Avatar    []byte
    Sex       byte
}

//更新一個用戶
func UpdateRoleData(role_id int32, role *Role) error {
    sqlStr := "update roles set role_id =?,role_name=?, avatar=?,sex=? where role_id = ?"
    ret, err := db.Exec(sqlStr, role.Role_id, role.Role_name, role.Avatar, role.Sex, role_id)
    if err != nil {
        fmt.Printf("update failed, err:%v\n", err)
        return err
    }
    n, err := ret.RowsAffected() // 操作影響的行數(shù)
    if err != nil {
        fmt.Printf("get RowsAffected failed, err:%v\n", err)
        return err
    }
    fmt.Printf("update success, affected rows:%d\n", n)
    return nil
}

//刪除一個用戶
func DeleteRoleData(role_id int32) error {
    sqlStr := "delete from roles where role_id = ?"
    ret, err := db.Exec(sqlStr, role_id) //執(zhí)行刪除語句
    if err != nil {
        fmt.Printf("delete failed, err:%v\n", err)
        return err
    }
    n, err := ret.RowsAffected() // 操作影響的行數(shù)
    if err != nil {
        fmt.Printf("get RowsAffected failed, err:%v\n", err)
        return err
    }
    fmt.Printf("delete success, affected rows:%d\n", n)
    return nil
}

//插入一條數(shù)據(jù)
func InsertRoleData(role *Role) error {
    //使用func (db *DB) Exec(query string, args ...interface{}) (Result, error)插入數(shù)據(jù)
    sql := "INSERT INTO `roles` (`role_id`, `role_name`, `sex`, `avatar`) VALUES (?, ?, ?, ?)"

    res, err := db.Exec(sql, role.Role_id, role.Role_name, role.Sex, role.Avatar)
    if err != nil {
        return err
    }
    fmt.Println("db.Exec success:=", res)
    return nil
}

// 查詢單條數(shù)據(jù)
func QueryRoleData(role *Role) error {

    sqlStr := "select * from `roles` where role_id= ? "
    // 非常重要:確保QueryRow之后調(diào)用Scan方法妓局,否則持有的數(shù)據(jù)庫鏈接不會被釋放
    err := db.QueryRow(sqlStr, 1).Scan(&role.Role_id, &role.Role_name, &role.Sex, &role.Avatar)
    if err != nil {
        fmt.Printf("scan failed, err:%v\n", err)
        return err
    }
    return nil
}

func main() {
    err := initDB()
    if err != nil {
        log.Fatalln(err)
    }
    data, err := ioutil.ReadFile("my.png")
    if err != nil {
        log.Println(err)
        return
    }
    role := &Role{
        Role_name: "jian",
        Avatar:    data,
        Sex:       1,
    }
    //插入一行數(shù)據(jù)
    err = InsertRoleData(role)
    if err != nil {
        log.Println("InsertRoleData err:=", err)
        return
    }

    //讀取一個role數(shù)據(jù)
    err = QueryRoleData(role)
    if err != nil {
        fmt.Println("QueryRoleData err:=", err)
    }
      //將讀取二進制保存到一個文件中
    //ioutil.WriteFile("newmy.png", role.Avatar, 0777)
  
      //刪除一個role
    err = DeleteRoleData(1)
    if err != nil {
        fmt.Println("DeleteRoleData err:=", err)
    }
    //更新一個role數(shù)據(jù)
    role.Role_id = 0
    err = UpdateRoleData(2, role)
    if err != nil {
        fmt.Println("UpdateRoleData err:=", err)
    }
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市呈宇,隨后出現(xiàn)的幾起案子好爬,更是在濱河造成了極大的恐慌,老刑警劉巖攒盈,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件抵拘,死亡現(xiàn)場離奇詭異,居然都是意外死亡型豁,警方通過查閱死者的電腦和手機僵蛛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進店門尚蝌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人充尉,你說我怎么就攤上這事飘言。” “怎么了驼侠?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵姿鸿,是天一觀的道長。 經(jīng)常有香客問我倒源,道長苛预,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任笋熬,我火速辦了婚禮热某,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘胳螟。我一直安慰自己昔馋,他們只是感情好,可當我...
    茶點故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布糖耸。 她就那樣靜靜地躺著秘遏,像睡著了一般。 火紅的嫁衣襯著肌膚如雪嘉竟。 梳的紋絲不亂的頭發(fā)上邦危,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天,我揣著相機與錄音周拐,去河邊找鬼铡俐。 笑死,一個胖子當著我的面吹牛妥粟,可吹牛的內(nèi)容都是我干的审丘。 我是一名探鬼主播,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼勾给,長吁一口氣:“原來是場噩夢啊……” “哼滩报!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起播急,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤脓钾,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后桩警,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體可训,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了握截。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片飞崖。...
    茶點故事閱讀 39,932評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖谨胞,靈堂內(nèi)的尸體忽然破棺而出固歪,到底是詐尸還是另有隱情,我是刑警寧澤胯努,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布牢裳,位于F島的核電站,受9級特大地震影響叶沛,放射性物質(zhì)發(fā)生泄漏蒲讯。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一恬汁、第九天 我趴在偏房一處隱蔽的房頂上張望伶椿。 院中可真熱鬧,春花似錦氓侧、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至旱捧,卻和暖如春独郎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背枚赡。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工氓癌, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人贫橙。 一個月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓贪婉,卻偏偏與公主長得像,于是被迫代替她去往敵國和親卢肃。 傳聞我的和親對象是個殘疾皇子疲迂,可洞房花燭夜當晚...
    茶點故事閱讀 44,884評論 2 354

推薦閱讀更多精彩內(nèi)容