使用 where in bookshelf / knex 过滤数据时出现问题

Trouble filtering data using where in bookshelf / knex

我是 bookshelf.js 的新手,正在我的 node.js + MySQL 项目中将其用于 ORM。 这个简单的查询出现错误。谁能告诉我哪里出错了?

//Get reviews for a service - TESTED
app.get('/api/review/:serviceID?', function(req, res) {
  var serviceID = req.params.serviceID;
  console.log("Service ID: " + serviceID);
  new Review.query('where','serviceID','=', serviceID)
    .fetchAll()
    .then(function(reviews) {
        if (reviews!=null)
            res.send(reviews.toJSON());
        else
            res.send("No reviews found");
    }).catch(function(error) {
        console.log(error);
        res.send('An error occurred in fetching reviews for service '+ serviceID);
    });
});

此处评论 table 将主键作为 reviewID,并将 serviceID 作为外键。 这是我收到的错误消息。

TypeError: Object [object Object] has no method 'forge'
  at new Model.(anonymous function).Collection.(anonymous function
  (d:\PMF\node_modules\bookshelf\bookshelf.js:146:24)
  at app.get.serviceID (d:\PMF\app.js:121:15)
  at Layer.handle [as handle_request]
  (d:\PMF\node_modules\express\lib\router\layer.js:82:5)
  at next (d:\PMF\node_modules\express\lib\router\route.js:110:13)
  at Route.dispatch (d:\PMF\node_modules\express\lib\router\route.js:91:3)
  at Layer.handle [as handle_request
  (d:\PMF\node_modules\express\lib\router\layer.js:82:5)
  at d:\PMF\node_modules\express\lib\router\index.js:267:22
  at param (d:\PMF\node_modules\express\lib\router\index.js:340:14)
  at param (d:\PMF\node_modules\express\lib\router\index.js:356:14)
  at Function.proto.process_params
  (d:\PMF\node_modules\express\lib\router\index.js:400:3)
  at next (d:\PMF\node_modules\express\lib\router\index.js:261:10)
  at jsonParser (d:\PMF\node_modules\body-parser\lib\types\json.js:96:40)
  at Layer.handle [as handle_request (d:\PMF\node_modules\express\lib\router\layer.js:82:5)
  at trim_prefix (d:\PMF\node_modules\express\lib\router\index.js:302:13)
  at d:\PMF\node_modules\express\lib\router\index.js:270:7
  at Function.proto.process_params (d:\PMF\node_modules\express\lib\router\index.js:321:12)
  at next (d:\PMF\node_modules\express\lib\router\index.js:261:10)
  at jsonParser (d:\PMF\node_modules\body-parser\lib\types\json.js:96:40)
  at Layer.handle [as handle_request] (d:\PMF\node_modules\express\lib\router\layer.js:82:5)
  at trim_prefix (d:\PMF\node_modules\express\lib\router\index.js:302:13)
  at d:\PMF\node_modules\express\lib\router\index.js:270:7
  at Function.proto.process_params (d:\PMF\node_modules\express\lib\router\index.js:321:12)
  at next (d:\PMF\node_modules\express\lib\router\index.js:261:10)
  at urlencodedParser (d:\PMF\node_modules\body-parser\lib\types\urlencoded.js:84:40)
  at Layer.handle [as handle_request] (d:\PMF\node_modules\express\lib\router\layer.js:82:5)
  at trim_prefix (d:\PMF\node_modules\express\lib\router\index.js:302:13)
  at d:\PMF\node_modules\express\lib\router\index.js:270:7
  at Function.proto.process_params (d:\PMF\node_modules\express\lib\router\index.js:321:12)

您的 Review 构造函数调用缺少括号:代码应为 new Review().query... 而不是 new Review.query...

附带说明一下,这种编写查询的更简单方法应该有效:

return new Review().where('serviceID', serviceID).fetchAll()