一.Gorm介绍
(一).什么是Gorm
Grom的全称是Object-Relationl Mapping,即对象关系映射,这里的Relationl指的是关系型数据库。
它的作用是在关系型数据库和对象之间作一个映射,这样,我们在具体的操作数据库的时候,就不需要再去和复杂的SQL语句打交道,只要像平时操作对象一样操作它就可以了。
(二).Gorm的特点
1.简单易用
gorm提供了简洁而直观的API,使得操作数据库变得非常容易。无论是创建、读取、更新还是删除数据,都可以通过简单的方法调用实现。
2.支持多种数据库
gorm支持多种常见的数据库系统,包括MySQL、PostgreSQL、SQLite等。这使得开发者可以在不同的项目中使用不同的数据库系统,而无需更改代码。
3.自动迁移
gorm具有强大的自动迁移功能,可以根据定义的模型自动创建、修改数据库表结构。这简化了数据库结构的管理,减少了手动处理数据库迁移的工作量。
4.事务支持
gorm支持事务操作,保证了数据库操作的原子性和一致性。在复杂的业务逻辑中,事务可以确保一系列操作要么全部成功,要么全部回滚,避免了数据不一致的问题。
5.强大的查询功能
gorm提供了丰富的查询功能,可以根据条件过滤数据、排序结果、限制返回的记录数等。开发者可以轻松地编写复杂的查询语句,满足各种业务需求。
二.Gorm使用
(一)下载Gorm库
直接使用命令下载安装Gorm
go get -u github.com/jinzhu/gorm
(二)连接数据库
1.首先,你需要在你的Go项目中导入gorm库:
import "gorm.io/gorm"
2.然后,你需要创建一个数据库连接,并初始化gorm的实例:
db, err := gorm.Open(mysql.Open("数据库连接字符串"), &gorm.Config{})
3.接下来,你可以定义你的数据模型,并使用gorm提供的API进行数据库操作。
package main
import (
"gorm.io/driver/mysql"
"gorm.io/gorm"
)
func main() {
// 用户名:密码@tcp(ip:port)/数据库?charset=utf8mb4&parseTime=True&loc=Local
dsn := "root:root123@tcp(127.0.0.1:3306)/test_gorm?charset=utf8mb4&parseTime=True&loc=Local"
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
if err != nil {
panic(err)
}
}
(三)表操作
1.创建表
package main
import (
"gorm.io/driver/mysql"
"gorm.io/gorm"
)
type User struct {
Id int
Name string
Age int
Addr string
Pic string
}
func main() {
// 用户名:密码@tcp(ip:port)/数据库?charset=utf8mb4&parseTime=True&loc=Local
dsn := "root:root123@tcp(127.0.0.1:3306)/test_gorm?charset=utf8mb4&parseTime=True&loc=Local"
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
if err != nil {
panic(err)
}
}
// 创建表时添加表后缀 db.Set("gorm:table_options", "ENGINE=InnoDB").AutoMigrate(&User{})
2.数据操作
实现数据的增删改查
// 增
db.Create(&User{
Name: "谦谦",
Age: 18,
Addr: "上海市",
Pic: "/static/img.png",
})
// 删
db.Delete(&user)
// 改
user.Name = "lisi"
db.Save(&user)
fmt.Println(user)
// 查
var user User
db.First(&user)
fmt.Println(user)