NodeJS + Невозможно прочитать свойство 'query' из undefined

0

Я новичок в NodeJS и хочу подключить образец базы данных с узлом js и результатом выборки. Я сделал шаги ниже.

  1. Установка My SQL на мой MAC-адрес
  2. Установка MyAQLWorkBench
  3. Создайте базу данных, таблицу и некоторую строку в таблице.
  4. Создать NodeJs приложение с помощью этого.
  5. Установите Atom.
  6. Установите мой SQL в приложении npm install mysql --save Приложение работает нормально без SQL-запроса и может видеть сообщения на локальном хосте, но при добавлении SQL-соединения и создает проблему и показывает ошибку. Cannot read property 'query' of undefined.

Мой код, как показано ниже в app.js

var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');
var mysql = require("mysql");
var bodyParser = require('body-parser');
var mysql= require('mysql');
var http = require('http');

var indexRouter = require('./routes/api/v1/index');
var usersRouter = require('./routes/api/v1/users');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', indexRouter);
app.use('/api/v1/users', usersRouter);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  next(createError(404));
});

//Database connection
app.use(function(req, res, next){
  console.log('In');
    res.locals.connection = mysql.createConnection({
        host     : '127.0.0.1',
        user     : 'root',
      password : 'q1w2e3r4t5',
        database : 'users'
    });
    res.locals.connection.connect();
  console.log('out');
    next();
});


// error handler
app.use(function(err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;
var server = http.createServer(app);
server.listen(4001);

В users.js мой код выглядит следующим образом:

router.get('/', function(req, res, next) {
res.locals.connection.query('SELECT * from userInfo', function (error, results, fields) {
        if(error){
            res.send(JSON.stringify({"status": 500, "error": error, "response": null}));
            //If there is error, we send the error in the error section with 500 status
        } else {
            res.send(JSON.stringify({"status": 200, "error": null, "response": results}));
            //If there is no error, all is good and response is 200OK.
        }
    });
});

Помогите решить эту проблему :( :)

  • 0
    По какой-то причине вы получаете res.locals.connection как undefined поэтому res.locals.connection ваш код, чтобы правильно получить значение res.locals.connection .
  • 0
    Привет Анкит, ты можешь помочь это сделать? Как я установил узел-отладчик 1.10.1, но он не работает, как упоминалось.
Показать ещё 4 комментария
Теги:
atom-editor
localhost

3 ответа

0
Лучший ответ

Перед объявлением маршрута вам необходимо объявить методы app.use.

См.: Экспресс-документы

Из документов:

Функции промежуточного программного обеспечения выполняются последовательно, поэтому порядок включения промежуточного программного обеспечения важен.

1

Попробуйте поместить код, который подключается к базе данных, до того, как вы укажете маршрут пользователя user.js:

    // view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

//Database connection
app.use(function(req, res, next){
  console.log('In');
    res.locals.connection = mysql.createConnection({
        host     : '127.0.0.1',
        user     : 'root',
      password : 'q1w2e3r4t5',
        database : 'users'
    });
    res.locals.connection.connect();
  console.log('out');
    next();
});


app.use('/', indexRouter);
app.use('/api/v1/users', usersRouter);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  next(createError(404));
});



// error handler
app.use(function(err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;
var server = http.createServer(app);
server.listen(4001);
  • 0
    плюс 1 к вам за ваш ответ тоже
1

То, как вы пытаетесь использовать это, является промежуточным программным обеспечением. Это означает, что при каждом вызове api будет создано новое соединение с базой данных. Это приведет к большому количеству подключений к базе данных при наличии большого количества параллельных запросов. В идеале вы должны создать только одно соединение и использовать его во всем приложении.

создать новый файл dbconnection.js

//create connection    
let connection = mysql.createConnection({
        host     : '127.0.0.1',
        user     : 'root',
        password : 'q1w2e3r4t5',
        database : 'users'
});
//export connection, you can optionally use 
//connection.connect here. The same state of this module is passed everywhere. 
exports.connection = connection;

теперь в вашем app.js, импортируйте это с помощью var connection = require('./dbconnection'); это автоматически создаст соединение.

Теперь вы можете использовать свое промежуточное программное обеспечение для установки соединения в res.locals, но не забудьте использовать его перед файлом маршрутов.

app.use(function(req, res, next){
  console.log('In');
  res.locals.connection = connection
  console.log('out');
  next();
});

...

app.use('/', indexRouter);
app.use('/api/v1/users', usersRouter);

Это должно выполнить эту работу.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню