使用 GORM连接数据库,实现增删改查丨青训营

112 阅读2分钟

一.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)