[go-zero] 子查询,使用到Squirrel包

使用到

实现sql:

SELECT count(1) FROM (SELECT 1 FROM tb_map_total WHERE deleted = 0 AND seasonId IN (1000016) AND stageIdList IN ('10008','10007') GROUP BY useMapId) AS tmp

Go 复制代码
	subBuilder := squirrel.Select("1").From(m.table).Where(squirrel.Eq{"deleted": 0})
	if len(seasonIdList) > 0 {
		subBuilder = subBuilder.Where(squirrel.Eq{"seasonId": seasonIdList})
	}
	if len(stageIdList) > 0 {
		subBuilder = subBuilder.Where(squirrel.Eq{"stageIdList": stageIdList})
	}
	subBuilder = subBuilder.GroupBy("useMapId")

	builder := squirrel.Select("count(1)").FromSelect(subBuilder, "tmp")

	sql, args, err := builder.ToSql()

	if err != nil {
		return 0
	}

	var resp int64

	err = m.conn.QueryRowCtx(ctx, &resp, sql, args...)

	switch err {
	case nil:
		return resp
	default:
		return 0
	}
相关推荐
QJtDK1R5a18 分钟前
C# 14 中的新增功能
开发语言·c#
大黄说说22 分钟前
Java 中 String 为何被设计为不可变?
开发语言
复园电子27 分钟前
KVM与Hyper-V虚拟化环境:彻底解决USB外设映射掉线的底层架构优化
开发语言·架构·php
2301_8035545228 分钟前
三大编程语言(Python/Go/C++)项目启动全解析
c++·python·golang
scan72431 分钟前
龙虾读取session历史消息
java·前端·数据库
kvo7f2JTy42 分钟前
JAVA 设计模式
java·开发语言·设计模式
仍然.1 小时前
多线程---阻塞队列收尾和线程池
java·开发语言·算法
TDengine (老段)1 小时前
TDengine IDMP 可视化 —— 饼图
大数据·数据库·人工智能·物联网·时序数据库·tdengine·涛思数据
认真的薛薛1 小时前
GPU运维:vllm启动大模型参数解析
运维·数据库·vllm
大尚来也1 小时前
红黑树与AVL树:平衡二叉搜索树的博弈与抉择
开发语言