【go】gorm\xorm\ent多表联查

文章目录

  • [1 gorm](#1 gorm)
  • [2 xorm](#2 xorm)
  • [3 ent](#3 ent)

前言:本文介绍golang三种orm框架联表查询

1 gorm

go 复制代码
type UserTest struct {
	Count     int     `json:"count,omitempty"`
	Type      string  `json:"type,omitempty"`
}
res := []UserTest{}
db.Joins("LEFT JOIN user ON order.user_id = user.id").Find(&res) 

2 xorm

go 复制代码
err := db.Table("user").Select("name as org, count(status) as count").
	Join("LEFT", "order", "user.id= order.user_id").
	In("name", orgNames).
	GroupBy("name").
	OrderBy("count(status) desc").Find(&res)

3 ent

go 复制代码
err := db.User.Query().
	Where(user.CompanyIDIn(companyIds...)).
	GroupBy(user.FieldCompanyID).
	Aggregate(
		func(s *sql.Selector) string {
			t := sql.Table(order.Table)
			s.Join(t).On(s.C(user.FieldID), t.C(order.FieldUserID))
			return sql.As(sql.Count(t.C(order.FieldBandwidth)), "count")
		},
	).Scan(c, &res)

输出:

json 复制代码
[
	{
		"type": "xxx",
		"count": 24
	},
	{
		"type": "yyy",
		"count": 65,
	}
]
相关推荐
斑鸠喳喳5 分钟前
模块系统 JPMS
java·后端
kunge20137 分钟前
【手写数字识别】之数据处理
后端
苦逼的老王7 分钟前
java之uniapp实现门店地图
java·开发语言·uni-app
SimonKing8 分钟前
Redis7系列:百万数据级Redis Search 吊打 ElasticSearch
后端
uhakadotcom11 分钟前
Python应用中的CI/CD最佳实践:提高效率与质量
后端·面试·github
一条晒干的咸魚13 分钟前
【C#学习笔记03】进制转换与反码、补码、原码
开发语言·笔记·学习·c#
十年之少39 分钟前
内存检测工具——Qt Creator
开发语言·qt
AI小智1 小时前
MCP:昙花一现还是未来标准?LangChain 创始人激辩实录
后端
bobz9651 小时前
strongswan IKEv1 proposal 使用
后端