Maison >interface Web >js tutoriel >La solution de NodeJs pour la gestion des exceptions de base de données
Erreur de lien de base de données
L'utilisation de nodejs pour gérer les exceptions est la plus gênante. Ici, je laisse de côté le domain
fourni par nodejs et certaines choses spécifiquement gérées par des tiers. bibliothèques du parti. L'exploitation de la base de données est une fonction couramment utilisée pour nous. Grâce aux rappels, nous aurons beaucoup d'erreurs ici.
est le suivant :
var pool = require('../db.js'); var runtimeLog = require('../log.js').getLogger('runlog'); var Promise = require('bluebird'); function queryPromise(queryString) { return new Promise(function(resolve, reject) { pool.getConnection(function(err, connection) { //connection.query(queryString, function(err, rows, fields) { // if (!err) { // resolve(rows); // } else { // runtimeLog.error(err) // reject(err) // } // connection.release(); //}); }) }) } module.exports = function() { return new Promise(function(resolve, reject) { queryPromise("select * from wb123_home_map GROUP BY onestair") .then(function(results){ resolve(results); }) .catch(function(err){ runtimeLog.error(err) }) }) }
Vous pouvez voir qu'il y a une possibilité d'erreur dans les deux rappels.
Et ceci est un module, nous l'avons exporté.
Ici, nous remplissons délibérément le mauvais numéro de port pour la connexion à la base de données, en l'écrivant comme 330666 :
module.exports = { host: '192.168.6.101', database: 'web123', user: 'root', password: 'passw0rd', protocol: 'mysql', port: '330666', query: {pool: true} }
Dans ce cas, lorsque nous nous connectons à la base de données, ce sera quelque chose qui s'est mal passé.
Ici, nous utilisons promise, donc dans la fonction exportée, nous utilisons catch, qui détectera l'erreur dans la fonction queryPromise et l'imprimera dans le journal.
[2017-01-05 13:27:59.648] [ERROR] runlog - [err] [RangeError: port should be >= 0 and < 65536: 330666] RangeError: port should be >= 0 and < 65536: 330666 ...
Erreur d'instruction SQL de base de données
Modifions le code, remplissons correctement le lien de la base de données, et modifier le SQL L'instruction est une instruction incorrecte.
var pool = require('../db.js'); var runtimeLog = require('../log.js').getLogger('runlog'); var Promise = require('bluebird'); function queryPromise(queryString) { return new Promise(function(resolve, reject) { pool.getConnection(function(err, connection) { connection.query(queryString, function(err, rows, fields) { //if (err) throw err; if (!err) { resolve(rows); } else { reject(err) } connection.release(); }); }) }) } module.exports = function() { return new Promise(function(resolve, reject) { queryPromise("select * from wb123_home_map GROUP BY onestairs") .then(function(results){ resolve(results); }) .catch(function(err){ runtimeLog.error('[err]',err) }) }) }
Message d'erreur :
[2017-01-05 14:40:14.518] [ERROR] runlog - [err] { [Error: ER_BAD_FIELD_ERROR: Unknown column 'onestairs' in 'group statement'] code: 'ER_BAD_FIELD_ERROR', errno: 1054, sqlState: '42S22', index: 0 } Error: ER_BAD_FIELD_ERROR: Unknown column 'onestairs' in 'group statement' at Query.Sequence._packetToError (E:\zz\zz_wb123\manage\trunk\code\nod ....
Vous pouvez voir que des erreurs sont générées via catch.
Donc, si Promise est utilisé, nous pouvons intercepter l'exception lancée ci-dessous directement dans le catch. Il n'est pas nécessaire de consigner les exceptions dans la fonction queryPromise.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!