Le noeud écrit et lit datatables avec la database Azure MS SQL à partir des routes

J'essaie d'insert des données dans ma database Azure puis de le lire. J'ai créé une configuration de données séparée et une connection globale, puis je peux y accéder à partir de n'importe où dans l'application. Le server a été connecté, cependant, lorsque j'ai écrit une fonction d'insertion dans une route, j'ai rencontré cette erreur: db.Request n'est pas un constructor dans la route index.js. Voici mes codes:

dbconfig.js:

const sql = require('mssql'); const config = { user: 'admin', password: 'admin', server: 'admin.database.windows.net', database: 'em-cryptolend-db', // If you are on Microsoft Azure, you need this: options: {encrypt: true} } const connection = sql.connect(config, err => { if(err) throw err; else console.log("SQL Server connected"); }) module.exports = connection; 

app.js:

 const http = require('http'); const express = require('express'); const exphbs = require('express-handlebars'); const path = require('path'); const bodyParser = require('body-parser'); const expressValidator = require('express-validator'); const sql = require('mssql'); const request = require('request'); // Express app setup const app = express(); // BodyParser Middleware app.use(bodyParser.json()); app.use(bodyParser.urlencoded({ extended: false })); // Express Validator app.use(expressValidator()); // Routes const routes = require('./routes/index'); const users = require('./routes/users'); app.use('/', routes); app.use('/users', users); // View engines app.set('views', path.join(__dirname, 'views')); app.engine('handlebars', exphbs({defaultLayout:'layout'})); app.set('view engine','handlebars'); // Static folder app.use(express.static(path.join(__dirname, 'public'))); // Listen to the server const port = process.env.PORT || 1337; const server = app.listn(port, function(){ console.log("Server started on port " + port); }); 

routes / index.js:

 const express = require('express'); const router = express.Router(); const db = require('../dbconfig'); // Get homepage router.get('/', function(req,res) { var request = new db.Request(); request.query("INSERT INTO dbo.lendbook (id, rate, amount, period, timestamp, type, frr) VALUES (8, 0.6, 5, 4, 2009-11-11 13:23:44.000, 'eth', 'bbb' )").then(function(recordset) { console.log('Recordset: ' + recordset); console.log('Affected: ' + request.rowsAffected); }).catch(function(err) { console.log('Request error: ' + err); }); }); module.exports = router; 

versions: noeud: 6.9.1 mssql: 4.0.4

Merci d'avance.

S'il vous plaît changer votre code comme ci-dessous:

dbconfig.js

 const sql = require('mssql'); const config = { user: 'admin', password: 'admin', server: 'admin.database.windows.net', database: 'em-cryptolend-db', // If you are on Microsoft Azure, you need this: options: {encrypt: true} } module.exports = config; 

routes / index.js

 const express = require('express'); const router = express.Router(); const config = require('../dbconfig'); const sql = require('mssql'); // Get homepage router.get('/', function(req, res) { sql.connect(config).then(function(err) { var request = new sql.Request().query("INSERT INTO dbo.lendbook (id, rate, amount, period, timestamp, type, frr) VALUES (8, 0.6, 5, 4, 2009-11-11 13:23:44.000, 'eth', 'bbb' )").then(function(recordset) { console.log('Recordset: ' + recordset); console.log('Affected: ' + recordset.rowsAffected); res.status(200).send('Inserted successfully.'); }).catch(function(err) { console.log('Request error: ' + err); res.status(500).send('Request error: ' + err); }); }) }); module.exports = router;