TypeOrm - 使用 queryBuilder 的 NestJS
TypeOrm - NestJS using queryBuilder
我在 mysql 中有这个数据库模式:
users_tbl
--------------------------------------------
id | first_name | last_name
--------------------------------------------
1 | Jon | Doe
2 | Mark | Smith
address_tbl
------------------------------------------------------------
id | address | city | user_id
------------------------------------------------------------
1 | some address | some city | 1
然后,我想使用 TypeOrm 的 queryBuilder 来获取 Jon Doe 的地址。
我的原始 sql 查询:
SELECT users.first_name, users.last_name, address.address, address.city FROM users INNER JOIN address ON address.user_id=users.id
我的 TypeOrm queryBuilder:
const users = await this.userRepo
.createQueryBuilder('users')
.select('users.first_name', 'fName')
.addSelect('users.last_name', 'lName')
.addSelect('adr.address', 'address')
.addSelect('adr.city', 'city')
.innerJoin('address', 'adr', 'adr.user_id=users.id')
.getMany();
return users;
似乎没有任何错误,因为我能够 运行 GET
请求。但是,它 returns 是一个空对象。在我的控制台中,NestJS(或 TypeORM)记录生成的 mysql 查询。这是:
SELECT adr.city AS city, adr.country AS country, adr.id AS adr_id, users.first_name AS fName, users.last_name AS lName FROM users users INNER JOIN address adr ON adr.user_id = users.id
我复制并粘贴它以在 phpmyadmin 中执行手动查询。查询似乎有效,并给了我预期的输出。我是不是在我的代码中遗漏了什么,或者这是某种 TypeORM 限制?
尝试使用 getRawMany
而不是 getMany
如下 -
return await this.userRepo
.createQueryBuilder('users')
.select('users.first_name', 'fName')
.addSelect('users.last_name', 'lName')
.addSelect('adr.address', 'address')
.addSelect('adr.city', 'city')
.innerJoin('address', 'adr', 'adr.user_id=users.id')
.printSql()
.getRawMany();
我在 mysql 中有这个数据库模式:
users_tbl
--------------------------------------------
id | first_name | last_name
--------------------------------------------
1 | Jon | Doe
2 | Mark | Smith
address_tbl
------------------------------------------------------------
id | address | city | user_id
------------------------------------------------------------
1 | some address | some city | 1
然后,我想使用 TypeOrm 的 queryBuilder 来获取 Jon Doe 的地址。
我的原始 sql 查询:
SELECT users.first_name, users.last_name, address.address, address.city FROM users INNER JOIN address ON address.user_id=users.id
我的 TypeOrm queryBuilder:
const users = await this.userRepo
.createQueryBuilder('users')
.select('users.first_name', 'fName')
.addSelect('users.last_name', 'lName')
.addSelect('adr.address', 'address')
.addSelect('adr.city', 'city')
.innerJoin('address', 'adr', 'adr.user_id=users.id')
.getMany();
return users;
似乎没有任何错误,因为我能够 运行 GET
请求。但是,它 returns 是一个空对象。在我的控制台中,NestJS(或 TypeORM)记录生成的 mysql 查询。这是:
SELECT adr.city AS city, adr.country AS country, adr.id AS adr_id, users.first_name AS fName, users.last_name AS lName FROM users users INNER JOIN address adr ON adr.user_id = users.id
我复制并粘贴它以在 phpmyadmin 中执行手动查询。查询似乎有效,并给了我预期的输出。我是不是在我的代码中遗漏了什么,或者这是某种 TypeORM 限制?
尝试使用 getRawMany
而不是 getMany
如下 -
return await this.userRepo
.createQueryBuilder('users')
.select('users.first_name', 'fName')
.addSelect('users.last_name', 'lName')
.addSelect('adr.address', 'address')
.addSelect('adr.city', 'city')
.innerJoin('address', 'adr', 'adr.user_id=users.id')
.printSql()
.getRawMany();