news 2026/6/10 17:37:50

NestJS-TypeORM QueryBuilder 常用 SQL 写法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
NestJS-TypeORM QueryBuilder 常用 SQL 写法

在 NestJS 项目中,this.xxxRepository.createQueryBuilder()是最常用、最规范的 QueryBuilder 使用方式。
本文以UserEntity为例,系统整理QueryBuilder 对应的常见 SQL 写法,所有示例可直接复制使用

一、基础准备

@Injectable() export class UserService { constructor( @InjectRepository(UserEntity) private readonly userRepository: Repository<UserEntity>, ) {} }

以下示例默认写在UserService中。

一、新增 & 更新 & 删除

1. INSERT

return this.userRepository .createQueryBuilder() .insert() .into(UserEntity) .values({ name: '张三', age: 18, status: 1, }) .execute();

批量新增

return this.userRepository .createQueryBuilder() .insert() .into(UserEntity) .values([ { name: '张三', age: 18 }, { name: '李四', age: 20 }, ]) .execute();

2. UPDATE

return this.userRepository .createQueryBuilder() .update(UserEntity) .set({ status: 0 }) .where('id = :id', { id }) .execute();

3. DELETE

return this.userRepository .createQueryBuilder() .delete() .from(UserEntity) .where('id = :id', { id }) .execute();

二、基础查询(SELECT)

1. 查询单表数据

SQL

SELECT * FROM user WHERE status = 1;

QueryBuilder

return this.userRepository .createQueryBuilder('u') .where('u.status = :status', { status: 1 }) .getMany();

2. 查询指定字段

SQL

SELECT id, name FROM user;
return this.userRepository .createQueryBuilder('u') .select(['u.id', 'u.name']) .getMany();

3. 查询单条数据

return this.userRepository .createQueryBuilder('u') .where('u.id = :id', { id }) .getOne();

三、WHERE 条件用法

1. 多条件 AND / OR

SQL

SELECT * FROM user WHERE age > 18 AND status = 1;
return this.userRepository .createQueryBuilder('u') .where('u.age > :age', { age: 18 }) .andWhere('u.status = :status', { status: 1 }) .getMany();

OR

.orWhere('u.role = :role', { role: 'admin' })

2. IN 查询

SQL

SELECT * FROM user WHERE id IN (1,2,3);
return this.userRepository .createQueryBuilder('u') .where('u.id IN (:...ids)', { ids: [1, 2, 3] }) .getMany();

3. LIKE 模糊查询

SQL

SELECT * FROM user WHERE name LIKE '%张%';
return this.userRepository .createQueryBuilder('u') .where('u.name LIKE :name', { name: `%张%` }) .getMany();

四、排序 & 分页

1. ORDER BY

return this.userRepository .createQueryBuilder('u') .orderBy('u.createTime', 'DESC') .getMany();

2. 分页查询

return this.userRepository .createQueryBuilder('u') .skip((page - 1) * pageSize) .take(pageSize) .getMany();

3. 分页 + 总数

return this.userRepository .createQueryBuilder('u') .skip((page - 1) * pageSize) .take(pageSize) .getManyAndCount();

五、JOIN 多表查询

1. LEFT JOIN

SQL

SELECT * FROM user u LEFT JOIN order o ON u.id = o.user_id;
return this.userRepository .createQueryBuilder('u') .leftJoin(OrderEntity, 'o', 'o.userId = u.id') .getMany();

2. LEFT JOIN 并返回关联数据

return this.userRepository .createQueryBuilder('u') .leftJoinAndSelect('u.orders', 'o') .getMany();

⚠️ 前提:UserEntity中定义了@OneToMany(() => OrderEntity, ...)

六、聚合函数(COUNT / SUM)

1. COUNT 查询

return this.userRepository .createQueryBuilder('u') .where('u.status = :status', { status: 1 }) .getCount();

2. GROUP BY 统计

SQL

SELECT status, COUNT(*) total FROM user GROUP BY status;
return this.userRepository .createQueryBuilder('u') .select('u.status', 'status') .addSelect('COUNT(*)', 'total') .groupBy('u.status') .getRawMany();

3. HAVING

return this.userRepository .createQueryBuilder('u') .select('u.status', 'status') .addSelect('COUNT(*)', 'total') .groupBy('u.status') .having('COUNT(*) > :count', { count: 10 }) .getRawMany();

七、子查询

1. 子查询 IN

SQL

SELECT * FROM user WHERE id IN (SELECT user_id FROM order WHERE amount > 100);
return this.userRepository .createQueryBuilder('u') .where(qb => { const subQuery = qb .subQuery() .select('o.userId') .from(OrderEntity, 'o') .where('o.amount > :amount') .getQuery(); return 'u.id IN ' + subQuery; }) .setParameter('amount', 100) .getMany();
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:50:55

视频PPT提取终极指南:从零开始快速掌握课件自动化

视频PPT提取终极指南&#xff1a;从零开始快速掌握课件自动化 【免费下载链接】extract-video-ppt extract the ppt in the video 项目地址: https://gitcode.com/gh_mirrors/ex/extract-video-ppt 还在为整理视频课程中的PPT内容而苦恼吗&#xff1f;每次观看教学视频&…

作者头像 李华
网站建设 2026/6/10 13:00:09

深蓝词库转换工具完全指南:跨平台输入法词库同步解决方案

深蓝词库转换工具完全指南&#xff1a;跨平台输入法词库同步解决方案 【免费下载链接】imewlconverter ”深蓝词库转换“ 一款开源免费的输入法词库转换程序 项目地址: https://gitcode.com/gh_mirrors/im/imewlconverter 在日常工作和生活中&#xff0c;我们经常面临输…

作者头像 李华
网站建设 2026/6/10 11:17:48

一键解锁Windows包管理器:winget-install让软件安装从未如此简单

一键解锁Windows包管理器&#xff1a;winget-install让软件安装从未如此简单 【免费下载链接】winget-install Install winget tool using PowerShell! Prerequisites automatically installed. Works on Windows 10/11 and Server 2022. 项目地址: https://gitcode.com/gh_m…

作者头像 李华
网站建设 2026/6/9 17:19:53

解锁NVIDIA显卡隐藏性能的实用指南:Profile Inspector深度使用教程

想要让你的NVIDIA显卡发挥出超越官方限制的性能表现吗&#xff1f;NVIDIA Profile Inspector这款工具能够让你直接访问显卡驱动的底层数据库&#xff0c;修改那些在官方控制面板中看不到的高级参数。无论是提升游戏帧率、优化画面质量&#xff0c;还是解决特定兼容性问题&#…

作者头像 李华