golang常用庫之操作資料庫的orm框架-gorm基本使用詳解
golang常用庫:gorilla/mux-http路由庫使用
golang常用庫:配置檔案解析庫-viper使用
golang常用庫:操作資料庫的orm框架-gorm基本使用
一:欄位對映-模型定義
gorm中通常用struct來對映欄位. gorm教程中叫模型定義
比如我們定義一個模型Model:
type User struct { gorm.Model UserId int64 `gorm:"index"` //設定一個普通的索引,沒有設定索引名,gorm會自動命名 Birtheday time.Time Age int `gorm:"column:age"`//column:一個tag,可以設定列名稱 Name string `gorm:"size:255;index:idx_name_add_id"`//size:設定長度大小,index:設定索引,這個就取了一個索引名 Num int `gorm:"AUTO_INCREMENT"` Email string `gorm:"type:varchar(100);unique_index"`//type:定義欄位型別和大小 AddressID sql.NullInt64 `gorm:"index:idx_name_add_id"` IgnoreMe int `gorm:"_"` Description string `gorm:"size:2019;comment:'使用者描述欄位'"`//comment:欄位註釋 Status string `gorm:"type:enum('published','pending','deleted');default:'pending'"` }
上面的gorm.Model 定義如下:
type Model struct { ID uint `gorm:"primary_key"`//primary_key:設定主鍵 CreatedAt time.Time UpdatedAt time.Time DeletedAt *time.Time }
當然我們也可以不用gorm.Model,自己定義一個差不多的型別
如果你用ID,系統會自動設為表的主鍵,當然我們可以自己定義主鍵:
比如:
// 使用`AnimalID`作為主鍵 type Animal struct { AnimalID int64 `gorm:"primary_key"` Name string Age int64 }
參考:https://gorm.io/zh_CN/docs/conventions.html
二:建立表
直接看下面的例子:createtable.go
package main import ( "database/sql" "fmt" "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql" "time" ) type User struct { gorm.Model UserId int64 `gorm:"index"` Birtheday time.Time Age int `gorm:"column:age"` Name string `gorm:"size:255;index:idx_name_add_id"` Num int `gorm:"AUTO_INCREMENT"` Email string `gorm:"type:varchar(100);unique_index"` AddressID sql.NullInt64 `gorm:"index:idx_name_add_id"` IgnoreMe int `gorm:"_"` Description string `gorm:"size:2019;comment:'使用者描述欄位'"` Status string `gorm:"type:enum('published','deleted');default:'pending'"` } //設定表名,預設是結構體的名的複數形式 func (User) TableName() string { return "VIP_USER" } func main() { db,err := gorm.Open("mysql","root:root@/gormdemo?charset=utf8&parseTime=True&loc=Local") if err != nil { fmt.Println("connect db err: ",err) } defer db.Close() if db.HasTable(&User{}) { //判斷表是否存在 db.AutoMigrate(&User{}) //存在就自動適配表,也就說原先沒欄位的就增加欄位 } else { db.CreateTable(&User{}) //不存在就建立新表 } }
上面的gorm.Open()操作,如果想指定主機話,就需要加上括號 ()
例如:
user:password@(localhost)/dbname?charset=utf8&parseTime=True&loc=Local
上面的程式中,先新建了一個數據庫名叫gormdemo
,然後執行:go run createtable.go
,成功執行後,資料庫就會出現一張名為 vip_user
的表。
三:增刪改查
新建一個gormdemo的資料庫,然後執行下面的sql語句,就會建立一個animals的表,裡面還有一些測試資料
CREATE TABLE `animals` ( `id` bigint(20) NOT NULL AUTO_INCREMENT,`name` varchar(255) DEFAULT 'galeone',`age` int(10) unsigned DEFAULT '0',PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=8 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of animals -- ---------------------------- INSERT INTO `animals` VALUES ('1','demo-test','20'); INSERT INTO `animals` VALUES ('2','galeone','30'); INSERT INTO `animals` VALUES ('3','demotest','30'); INSERT INTO `animals` VALUES ('4','jim','90'); INSERT INTO `animals` VALUES ('5','jimmy','10'); INSERT INTO `animals` VALUES ('6','23'); INSERT INTO `animals` VALUES ('7','test3','27');
增加
例子:create.go
package main import ( "fmt" "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql" ) type Animal struct { ID int64 Name string Age int64 } func main() { db,"root:root@/gormdemo?charset=utf8&parseTime=true&loc=Local") if err != nil { fmt.Println("connect db error: ",err) } defer db.Close() animal := Animal{Name: "demo-test",Age: 20} db.Create(&animal) }
說明:上面的這個例子,自己在mysql中建立一個animals的資料表,欄位為id,name,age
查詢
select.go
package main import ( "fmt" "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql" ) type Animal struct { ID int64 Name string Age int64 } //https://gorm.io/zh_CN/docs/query.html func main() { db,err) } defer db.Close() //根據逐漸查詢第一條記錄 var animal Animal db.First(&animal) fmt.Println(animal) //根據逐漸查詢最後一條記錄 var animal2 Animal db.Last(&animal2) fmt.Println(animal2) //指定某條記錄(僅當主鍵為整型時可用) var animal3 Animal db.First(&animal3,2) fmt.Println(animal3) //where條件 //符合條件的第一條記錄 var animal4 Animal db.Where("name = ?","demotest2").First(&animal4) fmt.Println("where : ",animal4,animal4.ID,animal4.Name,animal4.Age) //符合條件的所有記錄 var animals5 []Animal db.Where("name = ?","galeone").Find(&animals5) fmt.Println(animals5) for k,v := range animals5 { fmt.Println("k:",k,"ID:",v.ID,"Name:",v.Name,"Age:",v.Age) } //IN var animals6 []Animal db.Where("name IN (?)",[]string{"demo-test","demotest2"}).Find(&animals6) fmt.Println(animals6) //LIKE var animals7 []Animal db.Where("name like ?","%jim%").Find(&animals7) fmt.Println(animals7) //AND var animals8 []Animal db.Where("name = ? AND age >= ?","jim","24").Find(&animals8) fmt.Println(animals8) //總數 var count int var animals9 []Animal db.Where("name = ?","galeone").Or("name = ?","jim").Find(&animals9).Count(&count) fmt.Println(animals9) fmt.Println(count) //Scan,原生查詢 var animals10 []Animal db.Raw("SELECT id,name,age From Animals WHERE name = ? AND age = ? ","galeone","30").Scan(&animals10) fmt.Println("Scan: ",animals10) //原生查詢,select all var animals11 []Animal rows,_ := db.Raw("SELECT id,name FROM Animals").Rows() //注意:上面的 select id,name 後面不能寫成 * 代替,不然出來的結果都是預設0值 //像這樣結果: ALL: [{0 0} {0 0} {0 0} {0 0} {0 0} {0 0} {0 0}] //Scan 後面是什麼欄位,select 後面就緊跟什麼欄位 for rows.Next() { var result Animal rows.Scan(&result.ID,&result.Name) animals11 = append(animals11,result) } fmt.Println("ALL: ",animals11) //output:ALL: [{1 demo-test 0} {2 galeone 0} {3 demotest2 0} {4 galeone 0} {5 galeone 0} {6 jim 0} {7 jimmy 0}] //select 查詢 var animal12 Animal db.Select("name,age").Find(&animal12) //只查詢name,age欄位,相當於select name,age from user fmt.Println("select: ",animal12) // db.Select([]string{"name","age"}).Find(&animal12) // fmt.Println("select2: ",animal12) }
更新
update.go
package main import ( "fmt" "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql" ) type Animal struct { ID int64 Name string Age int64 } func main() { db,err) } defer db.Close() ///根據一個條件更新 //根據條件更新欄位值,//後面加Debug(),執行時,可以打印出sql db.Debug().Model(&Animal{}).Where("id = ? ",4).Update("name","jimupdate") //UPDATE `animals` SET `name` = 'jimupdate' WHERE (id = 4) //另外一種寫法: 根據條件更新 var animal Animal animal = Animal{ID: 3} db.Debug().Model(animal).Update("name","demotest2update") // db.Debug().Model(&animal).Update("name","demotest2update") // 這種寫法也可以 //UPDATE `animals` SET `name` = 'demotest2update' WHERE `animals`.`id` = 3 /// 多個條件更新 db.Model(&Animal{}).Where("id = ? AND age = ?",4,45).Update("name","jimupdate3") //UPDATE `animals` SET `name` = 'jimupdate2' WHERE (id = 4 AND age = 45) /// 更新多個值 db.Debug().Model(&Animal{}).Where("id = ?",4).Update(Animal{Name: "jim",Age: 90}) // UPDATE `animals` SET `age` = 90,`name` = 'jim' WHERE (id = 4) animal2 := Animal{ID: 5} db.Debug().Model(&animal2).Update(map[string]interface{}{"name": "jimm","age": 100}) //UPDATE `animals` SET `age` = 100,`name` = 'jimm' WHERE `animals`.`id` = 5 }
刪除
delete.go
package main import ( "fmt" "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql" ) type Animal struct { ID int64 Name string Age int64 } func main() { db,err) } defer db.Close() db.Debug().Where("id = ?",13).Delete(&Animal{}) // DELETE FROM `animals` WHERE (id = 13) db.Debug().Delete(&Animal{},"id = ? AND age = ?",14,10) //DELETE FROM `animals` WHERE (id = 14 AND age = 10) }
四:Debug
在db後面直接加上 Debug(), 比如delete.go 裡面的例子
五:參考
https://gorm.io/zh_CN/
到此這篇關於golang常用庫之操作資料庫的orm框架-gorm基本使用詳解的文章就介紹到這了,更多相關golang gorm使用內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!