具有参数和回调的Node.js函数不起作用

时间:2019-07-12 17:44:51

标签: javascript mysql callback nodejs-server

我正在编写一个API以按ID获取雇员,但是我遇到的问题是控制器在服务中调用了另一个函数,并将参数和回调传递给该函数。但是当函数调用回调函数时,出现错误。代码如下。我查看了在线示例并尝试对其进行故障排除,但失败了。对于没有参数的getall方法,我有一个类似的设置,它似乎可以正常工作。代码如下。

控制器代码是

  function getById(req, res, next) {
    userService.getById(req.params.id, (results) => {
      res.json(results);
        })
      .catch(err => next(err));
      }

服务代码是

 async function getById(id, callback) {database.query('SELECT * FROM employee WHERE id =' +id, (err, results) => {
       if (err) {
       callback(err);
       } else
        callback(results);
       });
      }

我得到的错误是:

TypeError: callback is not a function
    at Query.database.query (/user.service.js:52:7)
    at Query.<anonymous> (/Connection.js:525:10)
    at Query._callback (/Connection.js:491:16)
    at Query.Sequence.end (/Sequence.js:83:24)
    at Query.ErrorPacket (/Query.js:90:8)
    at Protocol._parsePacket (/Protocol.js:291:23)
    at Parser._parsePacket (/Parser.js:433:10)
    at Parser.write (/Parser.js:43:10)
    at Protocol.write (/Protocol.js:38:16)
    at Socket.<anonymous> (/Connection.js:91:28)
    at Socket.<anonymous> (/Connection.js:525:10)
    at Socket.emit (events.js:182:13)
    at addChunk (_stream_readable.js:283:12)
    at readableAddChunk (_stream_readable.js:264:11)
    at Socket.Readable.push (_stream_readable.js:219:10)
    at TCP.onread (net.js:639:20)

1 个答案:

答案 0 :(得分:0)

您正在混合概念:

function getById(req, res, next) {
    UserService.getById(id)
        .then(res => console.log(res))
        .catch(err => console.error(err))
}


function getById(id) {
    return new Promise((resolve, reject) => {
        database.query('SELECT * FROM employee WHERE id =' + id, (err, results) => {
            if (err) 
                reject(err)

            resolve(results)
        });
    })
}