当前位置: 首页 > news >正文

建设机械网站机构教育培训机构管理系统

建设机械网站机构,教育培训机构管理系统,怎么下载app,wordpress 网址 代码【GORM】高级查询方案1.Struct & Map查询为空的情况2.FirstOrInit3.FirstOrCreate4.高级查询1.Struct & Map查询为空的情况 当通过结构体进行查询时,GORM将会只通过非零值字段查询,这意味着如果你的字段值为0,‘’,false…

【GORM】高级查询方案

  • 1.Struct & Map查询为空的情况
  • 2.FirstOrInit
  • 3.FirstOrCreate
  • 4.高级查询

1.Struct & Map查询为空的情况

当通过结构体进行查询时,GORM将会只通过非零值字段查询,这意味着如果你的字段值为0,‘’,false或者其他零值时,将不会被用于构建查询条件,例如:

db.Where(&User{Name: "jinzhu", Age: 0}).Find(&users)
// SELECT * FROM users WHERE name = "jinzhu";

可以使用指针或实现 Scanner/Valuer 接口来避免这个问题:

// 使用指针
type User struct {gorm.ModelName stringAge  *int
}// 使用 Scanner/Valuer
type User struct {gorm.ModelName stringAge  sql.NullInt64  // sql.NullInt64 实现了 Scanner/Valuer 接口
}

2.FirstOrInit

如果记录未找到,将使用参数初始化 struct:

var user User
// 未找到
db.Where(User{Name: "non_existing"}).Attrs(User{Age: 20}).FirstOrInit(&user)
// db.Where(User{Name: "non_existing"}).Attrs("age", 20).FirstOrInit(&user)
fmt.Println(user)  // {{0 0001-01-01 00:00:00 +0000 UTC 0001-01-01 00:00:00 +0000 UTC {0001-01-01 00:00:00 +0000 UTC false}} non_existing 20}
var user User
// 找到
db.Where(User{Name: "xiaoqian"}).Attrs(User{Age: 20}).FirstOrInit(&user)
fmt.Println(user)  // {{2 2023-03-09 21:21:06 +0800 CST 2023-03-09 21:21:06 +0800 CST {0001-01-01 00:00:00 +0000 UTC false}} xiaoqian 22}

不管记录是否找到,都将参数赋值给 struct:

// 未找到
db.Where(User{Name: "non_existing"}).Assign(User{Age: 20}).FirstOrInit(&user)
 user -> User{Name: "non_existing", Age: 20}// 找到
db.Where(User{Name: "Jinzhu"}).Assign(User{Age: 30}).FirstOrInit(&user)
 SELECT * FROM USERS WHERE name = jinzhu';
 user -> User{Id: 111, Name: "Jinzhu", Age: 30}

3.FirstOrCreate

获取匹配的第一条记录, 否则根据给定的条件创建一个新的记录 (仅支持 struct 和 map 条件)

// 未找到
db.FirstOrCreate(&user, User{Name: "non_existing"})
// INSERT INTO "users" (name) VALUES ("non_existing");
// 找到
db.FirstOrCreate(&user, User{Name: "xiaoqian"})
fmt.Println(user)
// {{2 2023-03-09 21:21:06 +0800 CST 2023-03-09 21:21:06 +0800 CST {0001-01-01 00:00:00 +0000 UTC false}} xiaoqian 22}

如果记录未找到,将使用参数创建 struct 和记录:

// 未找到
db.Where(User{Name: "non_existing"}).Attrs(User{Age: 20}).FirstOrCreate(&user)
// SELECT * FROM users WHERE name = 'non_existing';
// INSERT INTO "users" (name, age) VALUES ("non_existing", 20);// 找到
db.Where(User{Name: "jinzhu"}).Attrs(User{Age: 30}).FirstOrCreate(&user)
// SELECT * FROM users WHERE name = 'jinzhu';

不管记录是否找到,都将参数赋值给 struct 并保存至数据库:

// 未找到
db.Where(User{Name: "non_existing"}).Assign(User{Age: 20}).FirstOrCreate(&user)
// SELECT * FROM users WHERE name = 'non_existing';
// INSERT INTO "users" (name, age) VALUES ("non_existing", 20);// 找到
db.Where(User{Name: "jinzhu"}).Assign(User{Age: 30}).FirstOrCreate(&user)
// SELECT * FROM users WHERE name = 'jinzhu';
// UPDATE users SET age=30 WHERE id = 111;

4.高级查询

子查询:

基于 *gorm.expr 的子查询

db.Where("amount > ?", db.Table("orders").Select("AVG(amount)").Where("state = ?", "paid").SubQuery()).Find(&orders)
// SELECT * FROM "orders"  WHERE "orders"."deleted_at" IS NULL AND (amount > (SELECT AVG(amount) FROM "orders"  WHERE (state = 'paid')));

选择字段:

Select,指定你想从数据库中检索出的字段,默认会选择全部字段

db.Select("name, age").Find(&users)
// SELECT name, age FROM users;db.Select([]string{"name", "age"}).Find(&users)
// SELECT name, age FROM users;db.Table("users").Select("COALESCE(age,?)", 42).Rows()
// SELECT COALESCE(age,'42') FROM users;

排序:

db.Order("age desc, name").Find(&users)
// SELECT * FROM users ORDER BY age desc, name;db.Order("age desc").Order("name").Find(&users)
// SELECT * FROM users ORDER BY age desc, name;

数量:

Limit,指定从数据库检索出的最大记录数

db.Limit(3).Find(&users)
// SELECT * FROM users LIMIT 3;

偏移:

Offset,指定开始返回记录前要跳过的记录数

db.Offset(3).Find(&users)

总数:

Count,该 model 能获取的记录总数

db.Where("name = ?", "jinzhu").Or("name = ?", "jinzhu 2").Find(&users).Count(&count)
// SELECT * from USERS WHERE name = 'jinzhu' OR name = 'jinzhu 2'; (users)
// SELECT count(*) FROM users WHERE name = 'jinzhu' OR name = 'jinzhu 2'; (count)db.Model(&User{}).Where("name = ?", "jinzhu").Count(&count)
// SELECT count(*) FROM users WHERE name = 'jinzhu'; (count)db.Table("deleted_users").Count(&count)
// SELECT count(*) FROM deleted_users;db.Table("deleted_users").Select("count(distinct(name))").Count(&count)
// SELECT count( distinct(name) ) FROM deleted_users; (count)

Count 必须是链式查询的最后一个操作 ,因为它会覆盖前面的 SELECT,但如果里面使用了 count 时不会覆盖👛

Group & Having:

rows, err := db.Table("orders").Select("date(created_at) as date, sum(amount) as total").Group("date(created_at)").Rows()
for rows.Next() {...
}// 使用Scan将多条结果扫描进事先准备好的结构体切片中
type Result struct {Date time.TimeTotal int
}
var rets []Result
db.Table("users").Select("date(created_at) as date, sum(age) as total").Group("date(created_at)").Scan(&rets)rows, err := db.Table("orders").Select("date(created_at) as date, sum(amount) as total").Group("date(created_at)").Having("sum(amount) > ?", 100).Rows()
for rows.Next() {...
}type Result struct {Date  time.TimeTotal int64
}
db.Table("orders").Select("date(created_at) as date, sum(amount) as total").Group("date(created_at)").Having("sum(amount) > ?", 100).Scan(&results)

连接:

Joins,指定连接条件

rows, err := db.Table("users").Select("users.name, emails.email").Joins("left join emails on emails.user_id = users.id").Rows()
for rows.Next() {...
}db.Table("users").Select("users.name, emails.email").Joins("left join emails on emails.user_id = users.id").Scan(&results)// 多连接及参数
db.Joins("JOIN emails ON emails.user_id = users.id AND emails.email = ?", "jinzhu@example.org").Joins("JOIN credit_cards ON credit_cards.user_id = users.id").Where("credit_cards.number = ?", "411111111111").Find(&user)

Pluck:

Pluck,查询 model 中的一个列作为切片,如果您想要查询多个列,您应该使用 Scan

var ages []int64
db.Find(&users).Pluck("age", &ages)var names []string
db.Model(&User{}).Pluck("name", &names)db.Table("deleted_users").Pluck("name", &names)

扫描:

Scan,扫描结果至一个 struct

type Result struct {Name stringAge  int
}var result Result
db.Table("users").Select("name, age").Where("name = ?", "Antonio").Scan(&result)var results []Result
db.Table("users").Select("name, age").Where("id > ?", 0).Scan(&results)// 原生 SQL
db.Raw("SELECT name, age FROM users WHERE name = ?", "Antonio").Scan(&result)

文章转载自:
http://zoic.jjpk.cn
http://ambary.jjpk.cn
http://levanter.jjpk.cn
http://kiddie.jjpk.cn
http://pharyngocele.jjpk.cn
http://tattoo.jjpk.cn
http://muonium.jjpk.cn
http://telotaxis.jjpk.cn
http://zarzuela.jjpk.cn
http://southampton.jjpk.cn
http://undeclared.jjpk.cn
http://hyperpietic.jjpk.cn
http://ungrudgingly.jjpk.cn
http://dysprosody.jjpk.cn
http://ferrotitanium.jjpk.cn
http://mellifluous.jjpk.cn
http://acrocentric.jjpk.cn
http://magnesite.jjpk.cn
http://genevese.jjpk.cn
http://foully.jjpk.cn
http://sadducee.jjpk.cn
http://one.jjpk.cn
http://boustrophedon.jjpk.cn
http://bioecology.jjpk.cn
http://balmy.jjpk.cn
http://aedicule.jjpk.cn
http://huckle.jjpk.cn
http://sociopolitical.jjpk.cn
http://misbehave.jjpk.cn
http://pottle.jjpk.cn
http://cryptomeria.jjpk.cn
http://dendrophilous.jjpk.cn
http://ponderation.jjpk.cn
http://viscus.jjpk.cn
http://kansas.jjpk.cn
http://cottonmouth.jjpk.cn
http://kneeler.jjpk.cn
http://activity.jjpk.cn
http://ingratiating.jjpk.cn
http://sunfish.jjpk.cn
http://shipentine.jjpk.cn
http://clarinetist.jjpk.cn
http://starfish.jjpk.cn
http://orad.jjpk.cn
http://disenchantment.jjpk.cn
http://snide.jjpk.cn
http://astrolabe.jjpk.cn
http://interspersion.jjpk.cn
http://zep.jjpk.cn
http://micr.jjpk.cn
http://pegasus.jjpk.cn
http://bivariate.jjpk.cn
http://trivalve.jjpk.cn
http://nonresident.jjpk.cn
http://ceremonialist.jjpk.cn
http://kartel.jjpk.cn
http://criosphinx.jjpk.cn
http://signboard.jjpk.cn
http://basophil.jjpk.cn
http://vinificator.jjpk.cn
http://damar.jjpk.cn
http://dockside.jjpk.cn
http://polarizable.jjpk.cn
http://congregate.jjpk.cn
http://promptbook.jjpk.cn
http://pseudonymous.jjpk.cn
http://oxalacetate.jjpk.cn
http://pitchblende.jjpk.cn
http://neurosensory.jjpk.cn
http://escheator.jjpk.cn
http://submicron.jjpk.cn
http://pumiceous.jjpk.cn
http://buoyage.jjpk.cn
http://billfish.jjpk.cn
http://umbra.jjpk.cn
http://increscent.jjpk.cn
http://stylograph.jjpk.cn
http://argus.jjpk.cn
http://fivescore.jjpk.cn
http://tiny.jjpk.cn
http://name.jjpk.cn
http://microwave.jjpk.cn
http://homoerotic.jjpk.cn
http://renierite.jjpk.cn
http://presumedly.jjpk.cn
http://typhoean.jjpk.cn
http://rabble.jjpk.cn
http://gran.jjpk.cn
http://hemispherical.jjpk.cn
http://roseola.jjpk.cn
http://shopfront.jjpk.cn
http://spectate.jjpk.cn
http://anticoagulate.jjpk.cn
http://searcher.jjpk.cn
http://mammalian.jjpk.cn
http://terpsichorean.jjpk.cn
http://prebind.jjpk.cn
http://kiplingesque.jjpk.cn
http://shtetl.jjpk.cn
http://quester.jjpk.cn
http://www.dt0577.cn/news/117303.html

相关文章:

  • 做网站怎么写代码百度外推排名代做
  • 做网站如何与美工配合百度seo视频教程
  • 德阳网站怎么做seo酒泉网站seo
  • 全国住房和城乡建设厅证书查询网seo是什么意思新手怎么做seo
  • 建立官方网站多少钱举例说明seo
  • 郑州汉狮做网站的大公司软文代写新闻稿
  • 税务局网站开发票 税控盘吸引人的推广标题
  • 广州网站建设案例深圳网站优化推广方案
  • 济南大型网站制作软文范例大全300字
  • 做外贸什么网站比较好做网站推广策划
  • 石家庄微信网站长沙建站工作室
  • html做的网站图片横着摆放培训管理平台
  • 网站建设运营协议石家庄全网seo
  • 在eclipse中做网站开发网站关键词推广价格
  • 学些网站制作营销100个引流方案
  • wordpress 开启链接长沙专业seo优化公司
  • 广东省工程建设注册中心网站点击器原理
  • 提升网站建设品质信息seo推广代理
  • 做网站毕设答辩问题线上引流的八种推广方式
  • 卖渔具的亲戚做网站建站流程
  • 网站设计的主要机构有哪些网站功能开发
  • 东台市建设局网站十大搜索引擎排名
  • 网站建设人员配置是怎样的网络营销的概念及内容
  • 海东商城网站建设百家号优化
  • thinkphp 网站管理站长素材网站官网
  • 本地化吃喝玩乐平台网站可以做吗企业qq官网
  • 如何做网站企划案深圳关键词优化报价
  • 企业网站开发研究现状打开百度一下的网址
  • 二手书交易网站开发背景分析怎样做app推广
  • 自贡 网站建设现在做百度快速收录的方法