Knex NodeJS并插入数据库

时间:2015-03-08 15:22:48

标签: mysql node.js knex.js

我是nodejs的新手并且正在尝试设置API服务器,这是我的第一次尝试。我想使用mysql而不是mongo db。

我的问题是' knex('用户')。insert({email:req.body.email});'似乎并不想保存到数据库。

            var dbConfig = {
              client: 'mysql',
              connection: {
                host     : 'localhost',
                user     : 'root',
                password : '',
                database : 'db_nodeapi'
              }
            };
            var express = require('express');                       // call express
            var bodyParser = require('body-parser');                // call body-parser
            var knex = require('knex')(dbConfig);                   // set up database connection
            var app = express();                                    // define our app using express
            app.use(bodyParser.urlencoded({ extended: true }));     // configure app to use bodyParser() 
            app.use(bodyParser.json());                             // this will let us get the data from a POST
            var router     = express.Router();                      // get an instance of the express Router
            router.use(function(req, res, next) {                   // middle ware for authentication
                console.log(' -Logging- ');
                next();                                             // continue to next route without stopping
            });
            router.get('/', function(req, res) {                    // listen for a post on root
                res.json({ message: ' -Success- ' });   
            });
            router.route('/user')                                   // set up user route
                .post(function(req, res) {                          // listen for a post on user
                    console.log(' -Post -');                        // report a post
                    knex('user').insert({email: req.body.email});   // insert user into user table
                    res.json({ success: true, message: 'ok' });     // respond back to request
                });
            app.use('/api', router);                                // register routes beginning with /api  
            var port = process.env.PORT || 8080;                    // set server port number
            app.listen(port);                                       // setup listener
            console.log('Magic happens on port ' + port);           // report port number chosen

问题是我无法将knex添加到数据库中!

CREATE TABLE IF NOT EXISTS `user` (
`id` int(11) NOT NULL,
  `email` varchar(255) NOT NULL
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=2 ;

这是数据库

3 个答案:

答案 0 :(得分:12)

您的代码中的问题是您错过了" .then"语句,它导致代码的实际执行。

   knex('user').insert({email: req.body.email})
      .then( function (result) {
          res.json({ success: true, message: 'ok' });     // respond back to request
       })

那应该有用。由于knex.js的insert函数是一个promise,你需要调用.then()来实际调用它。

答案 1 :(得分:1)

有人已经给出了解决方案。我在这里谈谈为什么添加然后语句可以解决这个问题。

事实上,然后 catch 声明都可以。请参阅knex文档(Ngram Tokenizer),其中提及:

  

将当前查询构建器链强制转换为承诺状态。

所以选择更新插入等只是查询语句构建器,您必须使用然后捕获将其转换为承诺状态。

示例如下:

knex('user').insert({email: req.body.email}) //not working
knex('user').insert({email: req.body.email}).then(()=>{}) //working
knex('user').insert({email: req.body.email}).catch(()=>{}) //working

.then(()=>{
    knex('user').insert({email: req.body.email}) //not working
    knex('user').insert({email: req.body.email}).then(()=>{}) //working
    knex('user').insert({email: req.body.email}).catch(()=>{}) //working
    return knex('user').insert({email: req.body.email}) //working
})

答案 2 :(得分:0)

有类似的问题一次,试试这个:

//...
router.route('/user').post(function(req, res) {                          
  knex('user').insert({email: req.body.email}).then(function(ret){
    res.json({ success: true, message: 'ok'/*,ret:ret*/});  
  });   
});
//...