Gorm 学习笔记

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")
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值