Kysely 项目中实现多计数与去重计数的查询方法
2025-05-19 22:29:32作者:何举烈Damon
Kysely 是一个类型安全的 SQL 查询构建器,它提供了强大的功能来构建复杂的 SQL 查询。在实际开发中,我们经常需要同时获取表的总记录数和某个字段的去重计数,这在数据分析场景中尤为常见。
基本查询需求
假设我们有一个用户表 tbl_user,需要同时查询:
- 表中的总用户数
- 不同职位(position)的总数
传统SQL写法如下:
SELECT
COUNT(*) AS total_users,
COUNT(DISTINCT position) AS total_positions
FROM tbl_user;
Kysely 的实现方式
Kysely 提供了内置的方法来实现这种多计数查询。核心在于使用 fn 函数构建器来创建聚合函数表达式:
const result = await db
.selectFrom("tbl_user")
.select(({ fn }) => [
fn.countAll().as("total_users"),
fn.count("position").distinct().as("total_positions"),
])
.execute();
技术解析
-
fn.countAll()
对应SQL中的COUNT(*),计算表中的所有记录数 -
fn.count().distinct()
这种链式调用方式对应SQL中的COUNT(DISTINCT column),实现了对指定列的去重计数 -
.as()方法
为每个计数结果指定别名,方便在结果对象中访问
实际应用场景
这种多计数查询在以下场景特别有用:
- 数据概览仪表盘
- 统计报表生成
- 数据质量检查(如检查字段的唯一值数量)
- 分页前的数据总量统计
类型安全优势
Kysely 的类型系统能够自动推断查询结果的类型。对于上面的查询,TypeScript 会自动推断出返回结果的类型为:
{
total_users: number;
total_positions: number;
}
这避免了手动定义类型的麻烦,也减少了类型错误的可能性。
性能考虑
虽然这种查询方式简洁明了,但在大数据量表上使用时需要注意:
- COUNT(DISTINCT) 操作可能比简单的 COUNT 更耗资源
- 如果只需要计数而不需要具体数据,确保不要添加不必要的字段到SELECT中
- 对计数字段添加适当的索引可以显著提高查询性能
通过Kysely的这种查询构建方式,开发者可以既保持代码的类型安全,又能以声明式的方法构建复杂的计数查询,大大提高了开发效率和代码的可维护性。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0255
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
JoyAI-VL-Interaction-Preview京东开源首个开源、视觉驱动的实时交互模型——它能实时监控视频流,并自主决定何时发言、保持沉默或委托任务。Jinja00
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0183
MaxKB强大易用的开源企业级智能体平台Python02
note-gen一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。TSX011
项目优选
收起
暂无描述
Dockerfile
787
5.17 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
900
2.09 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
721
1.45 K
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.14 K
1.18 K
deepin linux kernel
C
32
16
Ascend Extension for PyTorch
Python
768
995
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
472
482
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.51 K
689
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
1.08 K
684
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.05 K
277