Knex.js:如何从多个表中选择列?

psy*_*ron 4 mysql query-builder knex.js

示例查询,

SELECT a.driverID, a.dCarID, a.dDeviceID, b.carRegiNum FROM driverProfile a, carProfile b WHERE a.dManagerID = 7 AND b.carID=a.dCarID
Run Code Online (Sandbox Code Playgroud)

查询在 MySQL 上运行良好。driverProfile 和 carProfile 是两个单独的表。如果您需要更多说明,请发表评论。我被困在这里了。

感谢帮助。谢谢。

Use*_*ady 5

原始查询(分为行,以便我们可以阅读它[提示])

SELECT a.driverID, a.dCarID, a.dDeviceID, b.carRegiNum 
FROM driverProfile a, carProfile b 
WHERE a.dManagerID = 7 AND b.carID=a.dCarID
Run Code Online (Sandbox Code Playgroud)

第 1 步,连接语法(修复它!)

25 多年前,重新定义了连接中的 SQL 最佳实践,我们停止在表名之间使用逗号。请停下来……拜托!无论如何你都不能在 Knex.js 中做到这一点......所以最好习惯它。首先修复连接语法:

SELECT a.driverID, a.dCarID, a.dDeviceID, b.carRegiNum 
FROM driverProfile a
INNER JOIN carProfile b ON b.carID=a.dCarID
WHERE a.dManagerID = 7
Run Code Online (Sandbox Code Playgroud)

第 2 步,别名(不)

Knex 似乎也不容易做别名,所以用表名替换:

SELECT driverProfile.driverID, driverProfile.dCarID, driverProfile.dDeviceID, carProfile.carRegiNum 
FROM driverProfile
INNER JOIN carProfile ON carProfile.carID=driverProfile.dCarID
WHERE driverProfile.dManagerID = 7
Run Code Online (Sandbox Code Playgroud)

第 3 步,“Knexisfy”查询

knex.select(['driverProfile.driverID', 'driverProfile.dCarID', 'driverProfile.dDeviceID', 'carProfile.carRegiNum' ])
.from('driverProfile')
.innerJoin('carProfile','carProfile.carID','driverProfile.dCarID')
.where('driverProfile.dManagerID',7)
.then(function(output){
    //Deal with the output data here 
});
Run Code Online (Sandbox Code Playgroud)
  1. http://knexjs.org/#Builder-select
  2. http://knexjs.org/#Builder-from
  3. http://knexjs.org/#Builder-innerJoin
  4. http://knexjs.org/#Builder-where
  5. http://knexjs.org/#Interfaces-then