golang 中常用的数据持久化 orm 框架有:gorm、xorm 和 beego orm。gorm 轻量易用,支持多种数据库。xorm 强大灵活,提供丰富的特性。beego orm 简单易懂,主要支持 mysql 和 postgresql。
GoLang 框架:ORM 数据持久化指南
在 GoLang 中,使用对象关系映射 (ORM) 框架是实现数据持久化的一个流行且便捷的方法。本文将探究可用于实现这一目的的三个最受欢迎的 GoLang 框架:GORM、xorm 和 Beego ORM。
1. GORM:一个轻量级 ORM
GORM 是一个轻量级、易于使用的 ORM 框架。它支持不同的数据库,包括 MySQL、PostgreSQL、SQLite 和 Oracle。下面是一个使用 GORM 实现数据持久化的示例:
package main
import (
"gorm.io/gorm"
"log"
)
type User struct {
ID uint
Name string
Age int
}
func main() {
// 创建一个 gorm DB 实例
db, err := gorm.Open("mysql", "user:password@tcp(127.0.0.1:3306)/database?parseTime=true")
if err != nil {
log.Fatal(err)
}
// 自动迁移表结构
if err := db.AutoMigrate(&User{}); err != nil {
log.Fatal(err)
}
// 创建一条记录
user := User{Name: "John Doe", Age: 30}
if err := db.Create(&user).Error; err != nil {
log.Fatal(err)
}
// 查询一条记录
var result User
if err := db.First(&result, 1).Error; err != nil {
log.Fatal(err)
}
log.Printf("Queried user: %v", result)
}
2. xorm:一个功能丰富的 ORM
xorm 是另一个流行的 ORM 框架,它以其强大的特性和灵活性而闻名。它还支持多种数据库,包括 MySQL、PostgreSQL、SQLite 和 SQL Server。以下是如何使用 xorm 进行数据持久化:
package main
import (
"fmt"
"xorm.io/xorm"
)
type User struct {
ID int64
Name string
Age int
}
func main() {
// 创建一个 xorm engine
engine, err := xorm.NewEngine("mysql", "user:password@tcp(127.0.0.1:3306)/database?parseTime=true")
if err != nil {
fmt.Println(err)
return
}
// 同步表结构(如果不存在则创建)
if err := engine.Sync2(new(User)); err != nil {
fmt.Println(err)
return
}
// 插入一条记录
user := User{Name: "Jane Doe", Age: 25}
_, err = engine.InsertOne(user)
if err != nil {
fmt.Println(err)
return
}
// 查询一条记录
var result User
has, err := engine.ID(1).Get(&result)
if err != nil {
fmt.Println(err)
return
}
if has {
fmt.Println("Queried user:", result)
}
}
3. Beego ORM:一个简单易用的 ORM
Beego ORM 是一个简单易用的 ORM 框架,它是 Beego web 框架的一部分。它主要支持 MySQL 和 PostgreSQL 数据库。这是一个使用 Beego ORM 进行数据持久化的示例:
package main
import (
"beego/orm"
"fmt"
)
type User struct {
ID int
Name string
Age int
}
func main() {
// 注册模型
orm.RegisterModel(new(User))
// 创建一个 ormer
o := orm.NewOrm()
// 同步表结构
o.Syncdb("default")
// 插入一条记录
user := User{Name: "Bob Smith", Age: 28}
_, err := o.Insert(&user)
if err != nil {
fmt.Println(err)
return
}
// 查询一条记录
var result User
err = o.QueryTable("user").Filter("ID", 1).One(&result)
if err != nil {
fmt.Println(err)
return
}
fmt.Println("Queried user:", result)
}