gorm快速上手 Quick start
数据库连接
1.Sqlite数据库
package main
import (
"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/sqlite"
)
func main() {
//打开数据库连接
var db, _ = gorm.Open("sqlite3", "demo.db")
//关闭数据库连接
defer db.Close()
}
2.MySQL数据库
数据库连接字符串格式即DSN (Data Source Name)格式为:
[username[:password]@][protocol[(address)]]/dbname[?param1=value1&...¶mN=valueN]
package main
import (
"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/mysql"
)
func main() {
//打开数据库连接
db, _ := gorm.Open("mysql", "demo:123456@(localhost)/demo?charset=utf8&parseTime=True&loc=Local")
//关闭数据库连接
defer db.Close()
}
操作示例
1.CURD基础操作
package main
import (
"fmt"
"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/sqlite"
)
type User struct {
gorm.Model
Name string
Age int
}
func main() {
//打开数据库连接
var db, _ = gorm.Open("sqlite3", "demo.db")
//关闭数据库连接
defer db.Close()
//添加数据库表名前缀
gorm.DefaultTableNameHandler = func(db *gorm.DB, defaultTableName string) string {
return "demo_" + defaultTableName
}
//创建表
db.AutoMigrate(&User{})
user := User{
Name: "demo",
Age: 20,
}
//插入数据
db.Create(&user)
//查询数据
db.First(&user, "name = ?", "demo")
println(fmt.Sprintf("%v", user))
//更新数据
user.Age = 21
db.Save(&user)
//查询数据
db.First(&user, "name = ?", "demo")
println(fmt.Sprintf("%v", user))
//删除数据,软删除(存在deleted_at字段自动软删除,给deleted_at字段赋值就标记为删除)
db.Delete(&user)
//物理删除
db.Unscoped().Delete(&user)
var count = 0
//查询总数
db.Model(&User{}).Count(&count)
println("user count: ", count)
println("OK")
}
2.表关联
假设场景
有个学生Student,该Student有多本书Book
package main
import (
"github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/mysql"
)
type Book struct {
gorm.Model
StudentId int //关联Student表
Name string
ISBN string
Price float32
}
type Student struct {
gorm.Model
Name string
Age int
Books []Book
}
func main() {
//打开数据库连接
db, _ := gorm.Open("mysql", "demo:123456@(localhost)/demo?charset=utf8&parseTime=True&loc=Local")
//关闭数据库连接
defer db.Close()
//创建表
db.AutoMigrate(&Student{}, &Book{})
book1 := Book{
Name: "Go语言实战",
ISBN: "9787115445353",
Price: 59.00,
}
book2 := Book{
Name: "Go程序设计语言",
ISBN: "9787111558422",
Price: 79.00,
}
student := Student{
Name: "demo",
Age: 25,
Books: []Book{book1, book2},
}
//插入数据,将写入一条student记录和两条与之关联的book记录
db.Create(&student)
//查询student关联的所有book信息
var books []Book
db.Model(&student).Related(&books)
for _, book := range books {
println(book.Name)
}
println("OK")
}
连接池配置
只有在面向连接的数据库才能设置连接池,比如MySQL或PostgreSQL
而基于文件的数据库,如Sqlite是不能设置连接池的
db.DB()返回*sql.DB通用接口,通过该接口可以配置底层数据库连接参数
// SetMaxIdleCons 设置连接池中的最大闲置连接数。
db.DB().SetMaxIdleConns(10)
// SetMaxOpenCons 设置数据库的最大连接数量。
db.DB().SetMaxOpenConns(100)