溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Go中如何使用xorm操作mysql

發(fā)布時(shí)間:2022-01-10 10:49:05 來(lái)源:億速云 閱讀:174 作者:iii 欄目:開(kāi)發(fā)技術(shù)

本文小編為大家詳細(xì)介紹“Go中如何使用xorm操作mysql”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Go中如何使用xorm操作mysql”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來(lái)學(xué)習(xí)新知識(shí)吧。

xorm

官方介紹:xorm 是一個(gè)簡(jiǎn)單而強(qiáng)大的 Go 語(yǔ)言 ORM 庫(kù)。

通過(guò)它可以使數(shù)據(jù)庫(kù)操作非常簡(jiǎn)便。

xorm 的目標(biāo)并不是讓你完全不去學(xué)習(xí) SQL,我們認(rèn)為 SQL 并不會(huì)為 ORM 所替代,但是 ORM 將可以解決絕大部分的簡(jiǎn)單 SQL 需求。

xorm 支持兩種風(fēng)格的混用。  

xorm 還提供了工具,通過(guò) reverse 命令根據(jù)數(shù)據(jù)庫(kù)的表結(jié)構(gòu)生成對(duì)應(yīng)的 struct,省去了人工組織代碼的工作,十分方便。官方地址:https://xorm.io/

安裝

瀏覽 xorm 的 github 地址,我們要下載 2 個(gè)包,https://github.com/go-xorm

Go中如何使用xorm操作mysql

1、xorm 驅(qū)動(dòng)包,我們使用 xorm 的核心包 2、cmd 工具包,用于使用 reverse 命令生成數(shù)據(jù)表對(duì)應(yīng)的 struct

通過(guò) go get 命令分別下載 2 個(gè)包
go get github.com/go-xorm/xorm``go get github.com/go-xorm/cmd/xorm
下載完成后 github.com 文件夾下會(huì)出現(xiàn) go-xorm 包

Go中如何使用xorm操作mysql

生成數(shù)據(jù)結(jié)構(gòu) struct

本地?cái)?shù)據(jù)庫(kù) test 有 2 張數(shù)據(jù)表,doctor_tb 和 user_tb, 數(shù)據(jù)結(jié)構(gòu)如下:

Go中如何使用xorm操作mysql

Go中如何使用xorm操作mysql

我們現(xiàn)在就來(lái)生成這 2 張數(shù)據(jù)表的結(jié)構(gòu)模型。

1、在任意項(xiàng)目下新建一個(gè)文件夾 xorm_models,文件名沒(méi)有規(guī)定,為了存放生成的代碼文件。
2、拷貝 cmd 工具包中的摸板目錄到 xorm_models 下,在文件目錄github.com\go-xorm\cmd\xorm\templates\goxorm

Go中如何使用xorm操作mysql

config 是生成的配置信息,struct.go.tpl 是數(shù)據(jù)摸板,允許自定義,可以根據(jù)自己的項(xiàng)目需求,修改摸板。一般不需要修改。

Go中如何使用xorm操作mysql

3、打開(kāi) cmd 命令行窗口,進(jìn)入 xorm_models 目錄下,執(zhí)行 reverse 命令:xorm reverse [數(shù)據(jù)庫(kù)類型] [數(shù)據(jù)庫(kù)連接串] [模板目錄](méi)xorm reverse mysql root:112233@tcp(127.0.0.1:3305)/test?charset=utf8 templates/goxorm  

Go中如何使用xorm操作mysql

4、數(shù)據(jù)結(jié)構(gòu)代碼會(huì)自動(dòng)生成在 xorm_models/models 目錄下。

Go中如何使用xorm操作mysql

我們能看到生成了和表名同名的 2 個(gè)數(shù)據(jù)結(jié)構(gòu)文件 doctor_tb.go 和 user_tb.go

package models  
import (  
    "time"  
)  
type DoctorTb struct {  
    Id      int       `xorm:"not null pk autoincr INT(11)"`  
    Name    string    `xorm:"default '' comment('姓名') VARCHAR(50)"`  
    Age     int       `xorm:"default 0 comment('年齡') INT(11)"`  
    Sex     int       `xorm:"default 0 comment('性別') INT(11)"`  
    Addtime time.Time `xorm:"DATETIME"`  
}

使用 xorm

xorm 支持鏈?zhǔn)降膶懛?/p>

engine.Where("age > ?", 40).Or("name like ?", "林%").OrderBy("Id desc").Find(&docList2) 也支持直接執(zhí)行 sql 語(yǔ)句engine.SQL("select * from doctor_tb where age > ?", 40).Find(&docList4)

附上增刪改查事務(wù)的 demo 例子,代碼里都有注釋,很容易看懂。xorm 的封裝比較友好,只要熟悉 sql 語(yǔ)句,即便不看文檔,也能順利的使用各種關(guān)鍵字。

package main  

import (  
    "fmt"  
    _ "github.com/go-sql-driver/mysql"  
    "github.com/go-xorm/xorm"  
    "goShare/xorm_models/models"  
    "time"  
)  

func main() {  

    var engine *xorm.Engine  
    //連接數(shù)據(jù)庫(kù)  
    engine, err := xorm.NewEngine("mysql", "root:112233@tcp(127.0.0.1:3305)/test?charset=utf8")  
    if err != nil {  
        fmt.Println(err)  
        return  
    }  
    //連接測(cè)試  
    if err := engine.Ping(); err != nil {  
        fmt.Println(err)  
        return  
    }  
    defer engine.Close() //延遲關(guān)閉數(shù)據(jù)庫(kù)  
    fmt.Println("數(shù)據(jù)庫(kù)鏈接成功")  

    //查詢單條數(shù)據(jù)  
    var doc models.DoctorTb  
    b, _ := engine.Where("name = ?", "鐘南山").Get(&doc)  
    if b {  
        fmt.Println(doc)  
    } else {  
        fmt.Println("數(shù)據(jù)不存在")  
    }  

    //查詢單條數(shù)據(jù)方式 2 會(huì)根據(jù)結(jié)構(gòu)體的  
    doc2 := models.DoctorTb{Name: "鐘南山"}  
    b, _ = engine.Get(&doc2)  
    fmt.Println(doc2)  

    //新增數(shù)據(jù)  
    doc3 := models.DoctorTb{0, "王醫(yī)生", 48, 1, time.Now()}  
    i3, _ := engine.InsertOne(doc3)  
    fmt.Println("新增結(jié)果:", i3)  

    //查詢列表  
    docList := make([]models.DoctorTb, 0)  
    engine.Where("age > ? or name like ?", 40, "林%").Find(&docList)  
    fmt.Println("docList:", docList)  

    //查詢列表方式 2  
    docList2 := make([]models.DoctorTb, 0)  
    engine.Where("age > ?", 40).Or("name like ?", "林%").OrderBy("Id desc").Find(&docList2)  
    fmt.Println("docList2:", docList2)  

    //查詢分頁(yè)  
    docList3 := make([]models.DoctorTb, 0)  
    page := 0     //頁(yè)索引  
    pageSize := 2 //每頁(yè)數(shù)據(jù)  
    limit := pageSize  
    start := page * pageSize  
    totalCount, err := engine.Where("age > ? or name like ?", 40, "林%").Limit(limit, start).FindAndCount(&docList3)  
    fmt.Println("總記錄數(shù):", totalCount, "docList3:", docList3)  

    //直接用語(yǔ)句查詢  
    docList4 := make([]models.DoctorTb, 0)  
    engine.SQL("select * from doctor_tb where age > ?", 40).Find(&docList4)  
    fmt.Println("docList4:", docList4)  

    //刪除  
    docDel := models.DoctorTb{Name: "王醫(yī)生"}  
    iDel, _ := engine.Delete(&docDel)  
    fmt.Println("刪除結(jié)果:", iDel)  

    //刪除方式 2  
    engine.Exec("delete from doctor_tb where Id = ?", 3)  

    //更新數(shù)據(jù)  
    doc5 := models.DoctorTb{Name: "鐘醫(yī)生"}  
    //更新數(shù)據(jù) ID 為 2 的記錄名字更改為“鐘醫(yī)生”  
    iUpdate, _ := engine.Id(2).Update(&doc5)  
    fmt.Println("更新結(jié)果:", iUpdate)  

    //指定表名查詢。Table()  
    user := models.UserTb{Id: 2}  
    b, _ = engine.Table("user_tb").Get(&user)  
    fmt.Println(user)  

    //事務(wù)  
    session := engine.NewSession()  
    defer session.Close()  
    err = session.Begin()  
    _, err = session.Exec("delete from doctor_tb where Id = ?", 6)  
    if err != nil {  
        session.Rollback()  
        return  
    }  
    _, err = session.Exec("delete from user_tb where Id = ?", 10)  
    if err != nil {  
        session.Rollback()  
        return  
    }  
    err = session.Commit()  
    if err != nil {  
        return  
    }  
    fmt.Println("事務(wù)執(zhí)行成功")  
}

讀到這里,這篇“Go中如何使用xorm操作mysql”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過(guò)才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI