XUnity.AutoTranslator:打破语言壁垒,让Unity游戏说你的语言
2026/4/22 21:06:45
在 NestJS 项目中,this.xxxRepository.createQueryBuilder()是最常用、最规范的 QueryBuilder 使用方式。
本文以UserEntity为例,系统整理QueryBuilder 对应的常见 SQL 写法,所有示例可直接复制使用。
@Injectable() export class UserService { constructor( @InjectRepository(UserEntity) private readonly userRepository: Repository<UserEntity>, ) {} }以下示例默认写在UserService中。
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();return this.userRepository .createQueryBuilder() .update(UserEntity) .set({ status: 0 }) .where('id = :id', { id }) .execute();return this.userRepository .createQueryBuilder() .delete() .from(UserEntity) .where('id = :id', { id }) .execute();SQL
SELECT * FROM user WHERE status = 1;QueryBuilder
return this.userRepository .createQueryBuilder('u') .where('u.status = :status', { status: 1 }) .getMany();SQL
SELECT id, name FROM user;return this.userRepository .createQueryBuilder('u') .select(['u.id', 'u.name']) .getMany();return this.userRepository .createQueryBuilder('u') .where('u.id = :id', { id }) .getOne();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' })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();SQL
SELECT * FROM user WHERE name LIKE '%张%';return this.userRepository .createQueryBuilder('u') .where('u.name LIKE :name', { name: `%张%` }) .getMany();return this.userRepository .createQueryBuilder('u') .orderBy('u.createTime', 'DESC') .getMany();return this.userRepository .createQueryBuilder('u') .skip((page - 1) * pageSize) .take(pageSize) .getMany();return this.userRepository .createQueryBuilder('u') .skip((page - 1) * pageSize) .take(pageSize) .getManyAndCount();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();return this.userRepository .createQueryBuilder('u') .leftJoinAndSelect('u.orders', 'o') .getMany();⚠️ 前提:UserEntity中定义了@OneToMany(() => OrderEntity, ...)
return this.userRepository .createQueryBuilder('u') .where('u.status = :status', { status: 1 }) .getCount();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();return this.userRepository .createQueryBuilder('u') .select('u.status', 'status') .addSelect('COUNT(*)', 'total') .groupBy('u.status') .having('COUNT(*) > :count', { count: 10 }) .getRawMany();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();