欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

go xorm框架的使用

 更新時(shí)間:2021年05月22日 10:17:51   作者:是小張啊  
xorm框架和Spring Data Jpa有點(diǎn)相似,可以對(duì)比學(xué)習(xí),對(duì)于這個(gè)框架感覺(jué)還不錯(cuò),閑暇時(shí)間學(xué)習(xí)一下

一、創(chuàng)建數(shù)據(jù)庫(kù)連接

xorm支持單引擎和多引擎,多引擎的場(chǎng)景對(duì)于初學(xué)者來(lái)說(shuō),沒(méi)有必要考慮,所以我們主要學(xué)習(xí)的是單引擎的數(shù)據(jù)庫(kù)連接,為了方便檢查SQL,需要啟用打印功能,默認(rèn)不開(kāi)啟

var engine *xorm.Engine

func main() {
	var err error
	engine, err = xorm.NewEngine("mysql", "root:123456@tcp(127.0.0.1:3306)/myschool?charset=utf8")
	if err != nil {
		log.Println(err)
	}
    // 控制臺(tái)打印出生成的SQL語(yǔ)句
	engine.ShowSQL(true)
}

二、操作mysql數(shù)據(jù)庫(kù)

查詢

建表語(yǔ)句

CREATE TABLE `student`  (
  `id` varchar(225) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `name` varchar(225) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `age` int(11) NULL DEFAULT NULL,
  `gradeid` int(11) NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

CREATE TABLE `grade`  (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `gradename` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

struct結(jié)構(gòu)體

student.go

type Student struct {
	Id      string `orm:"id,primary" json:"id"`
	Name    string `orm:"name"       json:"name"`
	Age     int    `orm:"age"        json:"age"`
	Gradeid int    `orm:"gradeid"    json:"gradeid"`
}

grade.go

type Grade struct {
	Id        int    `orm:"id,primary" json:"id"`
	Gradename string `orm:"gradename"  json:"gradename"`
}

1、Get方法

Get方法用于獲取單條數(shù)據(jù),如:

結(jié)合Where查詢 ,寫(xiě)法很多,主要是剛?cè)腴T(mén),都可以嘗試一下。最終的實(shí)現(xiàn)都是一個(gè)意思

var stu student.Student
has, err := engine.Where("id=?", "1").Get(&stu)
  
stu := new(student.Student)
has, err := engine.Where("id=?", "1").Get(stu)
  
stu := student.Student{}
has, err := engine.Where("id=?", "1").Get(&stu)
  
stu := &student.Student{}
has, err := engine.Where("id=?", "1").Get(stu)
  
if err != nil {
  log.Println(err)
}
log.Println("是否存在:",has)
log.Println(stu)

結(jié)構(gòu)體中已有的非空數(shù)據(jù)查詢

stu := &student.Student{Id:"1"}
has, err := engine.Get(stu)
if err != nil {
   log.Println(err)
}
log.Println("是否存在:",has)
log.Println(stu)

has返回一個(gè)boolean類(lèi)型,表明數(shù)據(jù)是否存在,err接收如果在查詢中產(chǎn)生的錯(cuò)誤

2、Exist方法

Exist方法用于判斷數(shù)據(jù)是否存在,Get方法是以id字段舉例,那么現(xiàn)在就以name字段舉例

下面的寫(xiě)法也很怪異,猜測(cè)著去寫(xiě),很多東西都可以拓展開(kāi),剛?cè)腴T(mén),看啥都很神奇,隨便舉幾個(gè)例子,后面慢慢的去嘗試

has, err := engine.Where("name=?", "少杰").Exist(&student.Student{})

has, err := engine.Table(&student.Student{}).Where("name=?", "少杰").Exist()

has, err := engine.Exist(&student.Student{Name: "少杰"})
if err != nil {
    log.Println(err)
}
log.Println("是否存在:", has)

3、Find方法

Find方法用于查詢多條數(shù)據(jù) ,F(xiàn)ind方法的第一個(gè)參數(shù)為slice的指針或Map指針,即為查詢后返回的結(jié)果,第二個(gè)參數(shù)可選,為查詢的條件struct的指針。

stu := make([]student.Student, 0)
// Cols 查詢指定字段
// Limit 分頁(yè)查詢 (顯示的條數(shù),從第幾個(gè)開(kāi)始)
err := engine.Where("id=?", "1").Cols("name").Limit(10, 0).Find(&stus)
if err != nil {
    log.Println(err)
}
log.Println("查詢到的信息:", stu)

查詢時(shí)可以加入各種條件,也可以不加。不加時(shí)err := engine.Find(&stus)查詢所有,如果只選擇單個(gè)字段,也可使用非結(jié)構(gòu)體的Slice

var strings []string
// Table 需要操作的表名稱
err := engine.Table("student").Cols("id").Find(&strings)
if err != nil {
    log.Println(err)
}
log.Println("查詢到的信息:",strings)

4、Join方法

第一個(gè)參數(shù)為連接類(lèi)型,當(dāng)前支持INNER, LEFT OUTER, CROSS中的一個(gè)值, 第二個(gè)參數(shù)為string類(lèi)型的表名,表對(duì)應(yīng)的結(jié)構(gòu)體指針或者為兩個(gè)值的[]string,表示表名和別名, 第三個(gè)參數(shù)為關(guān)聯(lián)鍵。

每個(gè)學(xué)生只在一個(gè)班級(jí)出現(xiàn),所以對(duì)應(yīng)的結(jié)構(gòu)體應(yīng)該加上x(chóng)orm的index標(biāo)記

type Student struct {
	Id      string `orm:"id,primary" json:"id"`
	Name    string `orm:"name"       json:"name"`
	Age     int    `orm:"age"        json:"age"`
	Gradeid int    `orm:"gradeid"    json:"gradeid" xorm:"index"`
}
type Grade struct {
	Id        int    `orm:"id,primary" json:"id"`
	Gradename string `orm:"gradename"  json:"gradename"`
}

如果我們想查詢出兩張表的具體數(shù)據(jù),還需要借助xorm的extend關(guān)鍵字,類(lèi)似于java中的vo,而extend關(guān)鍵字的用處就是讀取的數(shù)據(jù)引用到struct,結(jié)構(gòu)體中extends標(biāo)記對(duì)應(yīng)的結(jié)構(gòu)順序應(yīng)和最終生成SQL中對(duì)應(yīng)的表出現(xiàn)的順序相同。

type Student struct {
	modle.Student `xorm:"extends"`
	modle.Grade   `xorm:"extends"`
}

// 查詢年紀(jì)時(shí)三年紀(jì)的學(xué)生
stu := make([]Student, 0)
err := engine.Where("gradeid=?", "3").Join("INNER", "grade", "grade.id = student.gradeid").Find(&stu)
if err != nil {
    log.Println(err)
}
log.Println("查詢到的信息:" , stu)

因?yàn)椴樵兊降臄?shù)據(jù)格式時(shí)數(shù)組,如果想獲取查詢出的數(shù)據(jù),可以采取循環(huán)數(shù)組的方式去遍歷

for _, value := range stu {
    log.Println("value:", value)
}

或者通過(guò)下標(biāo)去操作stu[0]去獲取學(xué)生的信息

5、Iterate方法

Iterate方法提供逐條執(zhí)行查詢到的記錄的方法,它所能使用的條件和Find方法完全相同

// Iterate 方法
err := engine.Where("age > ? ", 10).Iterate(new(modle.Student), func(i int, bean interface{}) error {
    stu := bean.(*modle.Student)
    log.Println("查詢到的信息:", stu, i)
    return nil
})

6、Count方法

統(tǒng)計(jì)數(shù)據(jù)使用Count方法,Count方法的參數(shù)為struct的指針并且成為查詢條件。

// Count 判斷有幾個(gè)
stuCount := new(modle.Student)
total, err := engine.Where("age >?", 10).Count(stuCount)
if err != nil {
    log.Println(err)
}
log.Println("年齡大于10的有", total, "個(gè)")

7、Rows方法

Rows方法和Iterate方法類(lèi)似,提供逐條執(zhí)行查詢到的記錄的方法,不過(guò)Rows更加靈活好用。

stu := new(modle.Student)
rows, err := engine.Where("age >?", 10).Rows(stu)
if err != nil {
    log.Println(err)
}
defer rows.Close()
for rows.Next() {
    err = rows.Scan(stu)
    if err != nil {
        log.Println(err)
    }
    log.Println("========", stu)
}

插入

Created可以讓您在數(shù)據(jù)插入到數(shù)據(jù)庫(kù)時(shí)自動(dòng)將對(duì)應(yīng)的字段設(shè)置為當(dāng)前時(shí)間

engine.TZLocation, _ = time.LoadLocation("Asia/Shanghai") 改變xorm的時(shí)區(qū)

type Student struct {
	Id      string `orm:"id,primary" json:"id"`
	Name    string `orm:"name"       json:"name"`
	Age     int    `orm:"age"        json:"age"`
	Gradeid int    `orm:"gradeid"    json:"gradeid" xorm:"index"`
	CreatedTime time.Time `xorm:"created"`
}
// 創(chuàng)建一個(gè)結(jié)構(gòu)體
var stuInsert modle.Student
stuInsert.Id = "3"
stuInsert.Name = "王五"
stuInsert.Age = 20
engine.Insert(&stuInsert)

更新

// 將id=1的用戶名稱修改為少杰
var stuUpdate modle.Student
stuUpdate.Name = "少杰"
affected, err := engine.Where("id=?", "1").Update(&stuUpdate)
if err != nil {
    log.Println(err)
}
log.Println("是否更新成功:", affected)

刪除

// 刪除一個(gè)id=3的學(xué)生
var stuDelete modle.Student
affected, err := engine.Where("id=?", "3").Delete(&stuDelete)
if err != nil {
    log.Println(err)
}
log.Println("是否刪除成功:", affected)

Column屬性定義

name 當(dāng)前field對(duì)應(yīng)的字段的名稱,可選,如不寫(xiě),則自動(dòng)根據(jù)field名字和轉(zhuǎn)換規(guī)則命名,如與其它關(guān)鍵字沖突,請(qǐng)使用單引號(hào)括起來(lái)。
pk 是否是Primary Key,如果在一個(gè)struct中有多個(gè)字段都使用了此標(biāo)記,則這多個(gè)字段構(gòu)成了復(fù)合主鍵,單主鍵當(dāng)前支持int32,int,int64,uint32,uint,uint64,string這7種Go的數(shù)據(jù)類(lèi)型,復(fù)合主鍵支持這7種Go的數(shù)據(jù)類(lèi)型的組合。
當(dāng)前支持30多種字段類(lèi)型,詳情參見(jiàn)本文最后一個(gè)表格 字段類(lèi)型
autoincr 是否是自增
[not ]null 或 notnull 是否可以為空
unique或unique(uniquename) 是否是唯一,如不加括號(hào)則該字段不允許重復(fù);如加上括號(hào),則括號(hào)中為聯(lián)合唯一索引的名字,此時(shí)如果有另外一個(gè)或多個(gè)字段和本unique的uniquename相同,則這些uniquename相同的字段組成聯(lián)合唯一索引
index或index(indexname) 是否是索引,如不加括號(hào)則該字段自身為索引,如加上括號(hào),則括號(hào)中為聯(lián)合索引的名字,此時(shí)如果有另外一個(gè)或多個(gè)字段和本index的indexname相同,則這些indexname相同的字段組成聯(lián)合索引
extends 應(yīng)用于一個(gè)匿名成員結(jié)構(gòu)體或者非匿名成員結(jié)構(gòu)體之上,表示此結(jié)構(gòu)體的所有成員也映射到數(shù)據(jù)庫(kù)中,extends可加載無(wú)限級(jí)
- 這個(gè)Field將不進(jìn)行字段映射
-> 這個(gè)Field將只寫(xiě)入到數(shù)據(jù)庫(kù)而不從數(shù)據(jù)庫(kù)讀取
<- 這個(gè)Field將只從數(shù)據(jù)庫(kù)讀取,而不寫(xiě)入到數(shù)據(jù)庫(kù)
created 這個(gè)Field將在Insert時(shí)自動(dòng)賦值為當(dāng)前時(shí)間
updated 這個(gè)Field將在Insert或Update時(shí)自動(dòng)賦值為當(dāng)前時(shí)間
deleted 這個(gè)Field將在Delete時(shí)設(shè)置為當(dāng)前時(shí)間,并且當(dāng)前記錄不刪除
version 這個(gè)Field將會(huì)在insert時(shí)默認(rèn)為1,每次更新自動(dòng)加1
default 0或default(0) 設(shè)置默認(rèn)值,緊跟的內(nèi)容如果是Varchar等需要加上單引號(hào)
json 表示內(nèi)容將先轉(zhuǎn)成Json格式,然后存儲(chǔ)到數(shù)據(jù)庫(kù)中,數(shù)據(jù)庫(kù)中的字段類(lèi)型可以為T(mén)ext或者二進(jìn)制
comment 設(shè)置字段的注釋(當(dāng)前僅支持mysql)

xorm框架簡(jiǎn)單的使用,慢慢學(xué)習(xí),慢慢進(jìn)步,加油少年!相信自己,本文章內(nèi)容可以參考文檔 http://xorm.topgoer.com/

以上就是go xorm框架的使用的詳細(xì)內(nèi)容,更多關(guān)于go xorm框架的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Golang加密解密之RSA(附帶php)

    Golang加密解密之RSA(附帶php)

    安全總是很重要的,各個(gè)語(yǔ)言對(duì)于通用的加密算法都會(huì)有實(shí)現(xiàn)。本文先是對(duì)RSA算法進(jìn)行了簡(jiǎn)單介紹,后才進(jìn)行介紹如何用Go實(shí)現(xiàn)RSA的加密解密,下面一起來(lái)看看吧。
    2016-08-08
  • Go Module依賴管理的實(shí)現(xiàn)

    Go Module依賴管理的實(shí)現(xiàn)

    Go Module是Go語(yǔ)言的官方依賴管理解決方案,其提供了一種簡(jiǎn)單、可靠的方式來(lái)管理項(xiàng)目的依賴關(guān)系,本文主要介紹了Go Module依賴管理的實(shí)現(xiàn),感興趣的可以了解一下
    2024-06-06
  • Go語(yǔ)言實(shí)現(xiàn)有規(guī)律的數(shù)字版本號(hào)的排序工具

    Go語(yǔ)言實(shí)現(xiàn)有規(guī)律的數(shù)字版本號(hào)的排序工具

    這篇文章主要為大家詳細(xì)介紹了如何利用Go語(yǔ)言實(shí)現(xiàn)有規(guī)律的數(shù)字版本號(hào)的排序工具,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2023-01-01
  • Go語(yǔ)言中并發(fā)的工作原理

    Go語(yǔ)言中并發(fā)的工作原理

    本文詳細(xì)講解了Go語(yǔ)言中并發(fā)的工作原理,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • Golang pipe在不同場(chǎng)景下遠(yuǎn)程交互

    Golang pipe在不同場(chǎng)景下遠(yuǎn)程交互

    這篇文章主要介紹了Golang pipe在不同場(chǎng)景下遠(yuǎn)程交互,pipe實(shí)現(xiàn)從一個(gè)進(jìn)程重定向至另一個(gè)進(jìn)程,它是雙向數(shù)據(jù)通道,用于實(shí)現(xiàn)進(jìn)行間通信
    2023-03-03
  • 淺談Go用于同步和并發(fā)控制的幾種常見(jiàn)鎖

    淺談Go用于同步和并發(fā)控制的幾種常見(jiàn)鎖

    本文主要介紹了淺談Go用于同步和并發(fā)控制的幾種常見(jiàn)鎖,包括互斥鎖、讀寫(xiě)鎖和一次性鎖等,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08
  • Go語(yǔ)言中defer語(yǔ)句的用法

    Go語(yǔ)言中defer語(yǔ)句的用法

    這篇文章介紹了Go語(yǔ)言中defer語(yǔ)句的用法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • go語(yǔ)言使用Chromedp實(shí)現(xiàn)二維碼登陸教程示例源碼

    go語(yǔ)言使用Chromedp實(shí)現(xiàn)二維碼登陸教程示例源碼

    這篇文章主要為大家介紹了go語(yǔ)言使用Chromedp實(shí)現(xiàn)二維碼登陸示例源碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • Golang開(kāi)發(fā)中常用的代碼片段匯總

    Golang開(kāi)發(fā)中常用的代碼片段匯總

    這篇文章主要給大家匯總了在Golang開(kāi)發(fā)中常用的代碼片段,這些代碼片段都是在日常工作中編寫(xiě)golang應(yīng)用時(shí)使用到,需要的朋友可以參考借鑒,下面跟著小編一起來(lái)學(xué)習(xí)學(xué)習(xí)吧。
    2017-07-07
  • Go位集合相關(guān)操作bitset庫(kù)安裝使用

    Go位集合相關(guān)操作bitset庫(kù)安裝使用

    這篇文章主要為大家介紹了Go位集合相關(guān)操作bitset庫(kù)安裝使用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07

最新評(píng)論