package main
import (
"fmt"
"gorm.io/driver/mysql"
"gorm.io/gorm"
"gorm.io/gorm/logger"
"gorm.io/gorm/schema"
"time"
)
//构建一张表,对应于数据库的表
type Record struct{
Id int
TableName string
LastId int64
CreatedAt time.Time
UpdatedAt time.Time
}
func main() {
dsn := "root:123456@tcp(localhost:3306)/sys?charset=utf8mb4&parseTime=True&loc=Local"
//连接数据库
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{
NamingStrategy: schema.NamingStrategy{
//TablePrefix: "gormv2_", //这里可以添加表的前缀
SingularTable: true,
},
Logger: logger.Default.LogMode(logger.Silent),
})
if err != nil {
panic(err)
}
//TODO:创建
//创建一条数据,通过数据的指针来创建
user := Record{Id: 211, TableName: "145381", LastId: 4533}
result := db.Create(&user)
//返回找到的记录数
fmt.Println(result.RowsAffected)
//这个想要创建成功,必须给Record结构体增加Name字段
db.Migrator().AddColumn(&Record{}, "Name")
//重命名字段
db.Migrator().RenameColumn(&Record{}, "id", "new_id")
//TODO:查询
//查找表是否存在的两种方式, Users首字母大小不影响查询
db.Migrator().HasTable("Record")
db.Migrator().HasTable(&Record{})
//查询users表是否存在id字段,输入ID、id、Id返回结果一样,都是true
db.Migrator().HasColumn(&Record{}, "id")
res := Record{}
ans := []int{}
//Select是查询一列,Where是查询一行
db.Model(&Record{}).Select("id", 1).Find(&ans)
db.Model(&Record{}).Where("id", 1).Find(&res)
//Find查询所有满足条件,改条件和Where的作用一样
var results []Record
db.Model(&Record{}).Find(&results, "id >= ?", 1)
//查找一列
var re []int
db.Model(&Record{}).Select("last_id").Find(&re)
//TODO:删除
//删除new_id字段
db.Migrator().DropColumn(&Record{}, "new_id")
}
Gorm 学习笔记
最新推荐文章于 2025-06-01 07:34:48 发布