初体验了一把go的GORM,感觉跟其他语言的ORM差不多,比较容易上手,而且官方文档也比较的齐全。
做一个简单的Demo记录。
官方网址:https://gorm.io/
首先肯定是导包操作,这里导的sql驱动按照实际导入
go get -u github.com/jinzhu/gorm
go get -u github.com/jinzhu/gorm/dialects/mysql
初体验的Demo
const (
Database = "mysql"
DatabaseName = "community"
Connection = "root:123@tcp(localhost:3306)"
)
//User struct
type User struct {
Name string
Pwd string
}
func main() {
var db *gorm.DB
db = initDataBase()
// 迁移模式
//db.AutoMigrate(&User{})
// Create
db.Create(&User{Name: "小白", Pwd: "654321"})
// Read -- 主键查询
var user User
db.First(&user, 1)
db.First(&user, "name = ?", "小白")
fmt.Println(user)
// Upate -- name段
db.Model(&user).Update("name", "小黑")
fmt.Println(user)
// Delete
db.Delete(&user)
closeDataBase(db)
}
func initDataBase() *gorm.DB {
db, err := gorm.Open(Database, fmt.Sprintf("%v/%v?charset=utf8mb4&parseTime=True&loc=Local", Connection, DatabaseName))
db.SingularTable(true)
if err != nil {
panic("Connection error")
}
return db
}
func closeDataBase(db *gorm.DB) {
err := db.Close()
if err != nil {
panic("dbClose error")
}
}
对于GORM,还有许多需要探索的地方,例如还有其提供的日志、自动迁移、模型关联等。