目錄
- 一、創(chuàng)建數(shù)據(jù)庫連接
- 二、操作mysql數(shù)據(jù)庫
- 查詢
- struct結(jié)構(gòu)體
- 1、Get方法
- 2、Exist方法
- 3、Find方法
- 4、Join方法
- 5、Iterate方法
- 6、Count方法
- 7、Rows方法
- 插入
- 更新
- 刪除
- Column屬性定義
一、創(chuàng)建數(shù)據(jù)庫連接
xorm支持單引擎和多引擎,多引擎的場景對于初學(xué)者來說,沒有必要考慮,所以我們主要學(xué)習(xí)的是單引擎的數(shù)據(jù)庫連接,為了方便檢查SQL,需要啟用打印功能,默認(rèn)不開啟
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)
}
// 控制臺打印出生成的SQL語句
engine.ShowSQL(true)
}
二、操作mysql數(shù)據(jù)庫
查詢
建表語句
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查詢 ,寫法很多,主要是剛?cè)腴T,都可以嘗試一下。最終的實現(xiàn)都是一個意思
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返回一個boolean類型,表明數(shù)據(jù)是否存在,err接收如果在查詢中產(chǎn)生的錯誤
2、Exist方法
Exist方法用于判斷數(shù)據(jù)是否存在,Get方法是以id字段舉例,那么現(xiàn)在就以name字段舉例
下面的寫法也很怪異,猜測著去寫,很多東西都可以拓展開,剛?cè)腴T,看啥都很神奇,隨便舉幾個例子,后面慢慢的去嘗試
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方法的第一個參數(shù)為slice的指針或Map指針,即為查詢后返回的結(jié)果,第二個參數(shù)可選,為查詢的條件struct的指針。
stu := make([]student.Student, 0)
// Cols 查詢指定字段
// Limit 分頁查詢 (顯示的條數(shù),從第幾個開始)
err := engine.Where("id=?", "1").Cols("name").Limit(10, 0).Find(stus)
if err != nil {
log.Println(err)
}
log.Println("查詢到的信息:", stu)
查詢時可以加入各種條件,也可以不加。不加時err := engine.Find(stus)查詢所有,如果只選擇單個字段,也可使用非結(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方法
第一個參數(shù)為連接類型,當(dāng)前支持INNER, LEFT OUTER, CROSS中的一個值, 第二個參數(shù)為string類型的表名,表對應(yīng)的結(jié)構(gòu)體指針或者為兩個值的[]string,表示表名和別名, 第三個參數(shù)為關(guān)聯(lián)鍵。
每個學(xué)生只在一個班級出現(xiàn),所以對應(yīng)的結(jié)構(gòu)體應(yīng)該加上xorm的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)鍵字,類似于java中的vo,而extend關(guān)鍵字的用處就是讀取的數(shù)據(jù)引用到struct,結(jié)構(gòu)體中extends標(biāo)記對應(yīng)的結(jié)構(gòu)順序應(yīng)和最終生成SQL中對應(yīng)的表出現(xiàn)的順序相同。
type Student struct {
modle.Student `xorm:"extends"`
modle.Grade `xorm:"extends"`
}
// 查詢年紀(jì)時三年紀(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)
因為查詢到的數(shù)據(jù)格式時數(shù)組,如果想獲取查詢出的數(shù)據(jù),可以采取循環(huán)數(shù)組的方式去遍歷
for _, value := range stu {
log.Println("value:", value)
}
或者通過下標(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)計數(shù)據(jù)使用Count方法,Count方法的參數(shù)為struct的指針并且成為查詢條件。
// Count 判斷有幾個
stuCount := new(modle.Student)
total, err := engine.Where("age >?", 10).Count(stuCount)
if err != nil {
log.Println(err)
}
log.Println("年齡大于10的有", total, "個")
7、Rows方法
Rows方法和Iterate方法類似,提供逐條執(zhí)行查詢到的記錄的方法,不過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ù)庫時自動將對應(yīng)的字段設(shè)置為當(dāng)前時間
engine.TZLocation, _ = time.LoadLocation("Asia/Shanghai") 改變xorm的時區(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)建一個結(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)
刪除
// 刪除一個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對應(yīng)的字段的名稱,可選,如不寫,則自動根據(jù)field名字和轉(zhuǎn)換規(guī)則命名,如與其它關(guān)鍵字沖突,請使用單引號括起來。 |
pk |
是否是Primary Key,如果在一個struct中有多個字段都使用了此標(biāo)記,則這多個字段構(gòu)成了復(fù)合主鍵,單主鍵當(dāng)前支持int32,int,int64,uint32,uint,uint64,string這7種Go的數(shù)據(jù)類型,復(fù)合主鍵支持這7種Go的數(shù)據(jù)類型的組合。 |
當(dāng)前支持30多種字段類型,詳情參見本文最后一個表格 |
字段類型 |
autoincr |
是否是自增 |
[not ]null 或 notnull |
是否可以為空 |
unique或unique(uniquename) |
是否是唯一,如不加括號則該字段不允許重復(fù);如加上括號,則括號中為聯(lián)合唯一索引的名字,此時如果有另外一個或多個字段和本unique的uniquename相同,則這些uniquename相同的字段組成聯(lián)合唯一索引 |
index或index(indexname) |
是否是索引,如不加括號則該字段自身為索引,如加上括號,則括號中為聯(lián)合索引的名字,此時如果有另外一個或多個字段和本index的indexname相同,則這些indexname相同的字段組成聯(lián)合索引 |
extends |
應(yīng)用于一個匿名成員結(jié)構(gòu)體或者非匿名成員結(jié)構(gòu)體之上,表示此結(jié)構(gòu)體的所有成員也映射到數(shù)據(jù)庫中,extends可加載無限級 |
- |
這個Field將不進(jìn)行字段映射 |
-> |
這個Field將只寫入到數(shù)據(jù)庫而不從數(shù)據(jù)庫讀取 |
- |
這個Field將只從數(shù)據(jù)庫讀取,而不寫入到數(shù)據(jù)庫 |
created |
這個Field將在Insert時自動賦值為當(dāng)前時間 |
updated |
這個Field將在Insert或Update時自動賦值為當(dāng)前時間 |
deleted |
這個Field將在Delete時設(shè)置為當(dāng)前時間,并且當(dāng)前記錄不刪除 |
version |
這個Field將會在insert時默認(rèn)為1,每次更新自動加1 |
default 0或default(0) |
設(shè)置默認(rèn)值,緊跟的內(nèi)容如果是Varchar等需要加上單引號 |
json |
表示內(nèi)容將先轉(zhuǎn)成Json格式,然后存儲到數(shù)據(jù)庫中,數(shù)據(jù)庫中的字段類型可以為Text或者二進(jìn)制 |
comment |
設(shè)置字段的注釋(當(dāng)前僅支持mysql) |
xorm框架簡單的使用,慢慢學(xué)習(xí),慢慢進(jìn)步,加油少年!相信自己,本文章內(nèi)容可以參考文檔 http://xorm.topgoer.com/
以上就是go xorm框架的使用的詳細(xì)內(nèi)容,更多關(guān)于go xorm框架的資料請關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:- go 實現(xiàn)簡易端口掃描的示例
- 解析Go的Waitgroup和鎖的問題
- Go語言快速入門圖文教程
- go語言基礎(chǔ) seek光標(biāo)位置os包的使用
- Go語言獲取文件的名稱、前綴、后綴
- Go語言 如何實現(xiàn)RSA加密解密
- Go 自定義package包設(shè)置與導(dǎo)入操作
- 詳解Gotorch多機定時任務(wù)管理系統(tǒng)