Golang Gorm 高级查询之where查询

插入测试数据


Go 复制代码
package main

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

type Student struct {
	ID    int64
	Name  string `gorm:"size:6"`
	Age   int
	Email *string
}

func (*Student) TableName() string {
	return "student"
}

func main() {
	dsn := "root:7PXjAkY!&nlR@tcp(192.168.11.128:3306)/test?charset=utf8mb4&parseTime=True&loc=Local"
	db, _ := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	db.AutoMigrate(&Student{})

	var sList []Student
	count := db.Find(&sList).Delete(&sList).RowsAffected
	fmt.Println("count=", count)
	email1 := "12396836709@qq.com"

	sList = []Student{
		{
			ID:    1,
			Name:  "lucas",
			Age:   30,
			Email: &email1,
		},
		{
			ID:    2,
			Name:  "yanzi",
			Age:   28,
			Email: &email1,
		},
		{
			ID:    3,
			Name:  "lulei",
			Age:   29,
			Email: &email1,
		},
		{
			ID:    4,
			Name:  "jerry",
			Age:   25,
			Email: &email1,
		},
	}
	db.Create(&sList)

}

Where语句里面条件 where + find = select * from table where...........


其实就是sql语句当中的where

Go 复制代码
	var sList []Student
	db.Debug().Where("name = ?", "lucas").Find(&sList)
	fmt.Println(sList)


[0.746ms] [rows:1] SELECT * FROM `student` WHERE name = 'lucas'
[{1 lucas 30 0xc0001c91f0}] 

之前学的这种写法也是可以的

Go 复制代码
	var s Student
	db.Debug().Find(&s, "name = ?", "lucas")
	fmt.Println(s)

[1.552ms] [rows:1] SELECT * FROM `student` WHERE name = 'lucas'              
{1 lucas 30 0xc0001c9300}  

使用结构体查询


如果是零值,那么查询的时候就不会将零值作为查询带上了

Go 复制代码
	s = Student{
		Name: "lucas",
		Age:  30,
	}
	db.Debug().Where(&s).Find(&s)

[1.543ms] [rows:1] SELECT * FROM `student` WHERE `student`.`name` = 'lucas' AND `student`.`age` = 30
相关推荐
tyler_download2 小时前
golang 实现比特币内核:处理椭圆曲线中的天文数字
golang·blockchain·bitcoin
疯狂的程需猿3 小时前
一个百度、必应搜索引擎图片获取下载的工具包
golang·图搜索
明月看潮生5 小时前
青少年编程与数学 02-003 Go语言网络编程 09课题、Cookie
青少年编程·golang·网络编程·编程与数学
明月看潮生5 小时前
青少年编程与数学 02-003 Go语言网络编程 15课题、Go语言URL编程
开发语言·网络·青少年编程·golang·编程与数学
明月看潮生5 小时前
青少年编程与数学 02-003 Go语言网络编程 14课题、Go语言Udp编程
青少年编程·golang·网络编程·编程与数学
hlsd#7 小时前
go 集成go-redis 缓存操作
redis·缓存·golang
qq_1728055920 小时前
GIN 反向代理功能
后端·golang·go
__AtYou__21 小时前
Golang | Leetcode Golang题解之第535题TinyURL的加密与解密
leetcode·golang·题解
kevin_tech1 天前
Go API 多种响应的规范化处理和简化策略
开发语言·后端·golang·状态模式
幺零九零零1 天前
【Golang】sql.Null* 类型使用(处理空值和零值)
数据库·sql·golang