go-数据库基本操作

1. 配置数据库

bash 复制代码
package main

import (
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
)
#配置表结构
type User struct {
	ID       int64 `json:"id" gorm:"primary_key"` // 主键ID自增长
	Username string
	Password string
}
#配置连接接信息
func main() {
	//
	dsn := "root:zhangfan@123@tcp(127.0.0.1:3306)/test_db?charset=utf8mb4&parseTime=True&loc=Local"
	db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	// err == nil 说明 连接成功
	if err != nil {
		panic("连接数据库失败")
	}
	}

2.创建表

go 复制代码
func main() {
	//
	dsn := "root:zhangfan@123@tcp(127.0.0.1:3306)/test_db?charset=utf8mb4&parseTime=True&loc=Local"
	db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	// err == nil 说明 连接成功
	if err != nil {
		panic("连接数据库失败")
	}
	// 1.自动创建表
	db.AutoMigrate(&User{})

3.增加数据

go 复制代码
			db.Create(&User{
				Username: "lisi",
				Password: "123456",
			})

4.查询数据

go 复制代码
		//4.查询
		//单个查询
		u := User{ID: 1}
		db.First(&u) //过滤其中一条
		fmt.Printf("%#v\n", u)
		// 查询所有数据
		users := []User{}          // 创建一个切片
		db.Find(&users)            // 查询并将结果填充到 users 切片中
		fmt.Printf("%#v\n", users) // 使用 %#v 格式化动词打印 users 切片的内容,包括类型信息和值

5.删除数据

bash 复制代码
	//5.删除
	// db.Delete(&User{ID: 2}) // 根据主见 删除 id 为 2 的用户
	// 条件删除
	db.Where("username = ?", "lisi").Delete(&User{})

6.创建一对多数据表

go 复制代码
package main

import (
	"fmt"
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
)

// 2.定义一个User表
type User struct {
	gorm.Model
	Username string `json:"username" gorm:"column:username"`
	//添加外键关联
	CreditCards []CreditCard
}

// 3.定义一个card表
type CreditCard struct {
	gorm.Model // gorm.Model包含了ID,CreatedAt,UpdatedAt,DeletedAt
	Number     string
	UserID     uint //这个就是与User表进行关联的外键 结构体+主键就是表关联的外键
}

func main() {
	// 1. 连接数据库
	dsn := "root:zhangfan@123@tcp(127.0.0.1:3306)/test_db?charset=utf8mb4&parseTime=True&loc=Local"
	db, _ := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	fmt.Println(db)
	db.AutoMigrate(User{}, CreditCard{}) //自动创建表结构
6.1 创建一对多数据

创建了一个zhangfan用户并插入两条数据

go 复制代码
		user := User{
			Username: "zhangfan",
			CreditCards: []CreditCard{ // 创建一个切片
				{Number: "0001"},
				{Number: "0002"},
			},
		}
		db.Create(&user)
6.1 插入一对多数据
go 复制代码
	//给zhangfan添加一条信用卡数据
	u := User{Username: "zhangfan"}
	db.First(&u)
	db.Model(&u).Association("CreditCards").Append(&CreditCard{Number: "0003"})
6.2 一对多数据关联查询

查询两次

go 复制代码
	// 查询关联数据,先查到用户,在根据用户ID查询关联的card数据
	u := User{Username: "zhangfan"}
	db.First(&u)  //查询user表的数据
	fmt.Printf("%#v\n", u.Username)
	err := db.Model(&u).Association("CreditCards").Find(&u.CreditCards)
	if err != nil {
		fmt.Println(err, "err")
	}
	//fmt.Println(u)
	strUser, _ := json.Marshal(&u)
	fmt.Println(string(strUser))

一次性查找

go 复制代码
	//预加载查询 通过 preload方法一对多查询
	users := []User{}
	db.Preload("CreditCards").Find(&users)
	strUser, _ := json.Marshal(&users)
	fmt.Println(string(strUser))
}

6.创建多对多数据表操作

go 复制代码
package main

import (
	"fmt"
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
)

func main() {
	// 1. 连接数据库
	dsn := "root:zhangfan@123@tcp(127.0.0.1:3306)/test_db?charset=utf8mb4&parseTime=True&loc=Local"
	db, _ := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	fmt.Println(db)
	// 创建表
	db.AutoMigrate(user{}, Language{})

}
// 定义多对多表结构
type user struct {
	gorm.Model
	Language []Language `gorm:"many2many:user_languages;"` // 定义多对多关系
}
type Language struct {
	gorm.Model
	Name string
}
相关推荐
念何架构之路9 分钟前
Go进阶之panic
开发语言·后端·golang
先跑起来再说12 分钟前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
亓才孓13 分钟前
[Properties]写配置文件前,必须初始化Properties(引用变量没执行有效对象,调用方法会报空指针错误)
开发语言·python
傻乐u兔16 分钟前
C语言进阶————指针3
c语言·开发语言
Σίσυφος190021 分钟前
PCL法向量估计 之 方向约束法向量(Orientation Guided Normal)
数据库
老毛肚24 分钟前
手写mybatis
java·数据库·mybatis
两点王爷26 分钟前
Java基础面试题——【Java语言特性】
java·开发语言
海山数据库29 分钟前
移动云大云海山数据库(He3DB)postgresql_anonymizer插件原理介绍与安装
数据库·he3db·大云海山数据库·移动云数据库
云飞云共享云桌面33 分钟前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
Swift社区34 分钟前
Gunicorn 与 Uvicorn 部署 Python 后端详解
开发语言·python·gunicorn