ホームページ >ウェブフロントエンド >jsチュートリアル >NodeJs データベース例外処理の分析

NodeJs データベース例外処理の分析

小云云
小云云オリジナル
2018-01-22 10:15:321621ブラウズ

この記事は主に NodeJs におけるデータベース例外処理の簡単な説明を紹介しています。編集者が非常に優れていると考えたので、参考として共有します。編集者をフォローして見てみましょう。皆さんのお役に立てれば幸いです。

NodeJs バージョン: 4.4.4

データベース リンク エラー

nodejs を使用して例外を処理するのが最も面倒ですが、ここでは、nodejs が提供するもの domain とそれを特別に処理するいくつかのサードパーティ ライブラリについては脇に置きます。データベースの操作は私たちにとってよく使われる機能です。コールバックを使用すると、ここで多くのエラーが発生します。

以下の通り:


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)
      })
  })
}

両方のコールバックでエラーが発生する可能性があることがわかります。

そしてこれはモジュールであり、エクスポートしました。

ここでは、データベース接続用に意図的に間違ったポート番号を入力し、 330666:


module.exports = {
  host:   '192.168.6.101',
  database: 'web123',
  user:   'root',
  password: 'passw0rd',
  protocol: 'mysql',
  port:   '330666',
  query:  {pool: true}
}

この場合、データベースに接続するときにエラーが発生します。

ここでは Promise を使用しているため、エクスポートされた関数で catch を使用します。これにより、queryPromise 関数でエラーがキャッチされ、ログに出力されます。


[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
...

データベース SQL ステートメント エラー

コードを変更し、データベース リンクを正しく記入し、SQL ステートメントを間違ったステートメントに変更しましょう。


var pool = require(&#39;../db.js&#39;);
var runtimeLog = require(&#39;../log.js&#39;).getLogger(&#39;runlog&#39;);
var Promise = require(&#39;bluebird&#39;);

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(&#39;[err]&#39;,err)
      })
  })
}

エラーメッセージ:


[2017-01-05 14:40:14.518] [ERROR] runlog - [err] { [Error: ER_BAD_FIELD_ERROR: Unknown column &#39;onestairs&#39; in &#39;group statement&#39;]
 code: &#39;ER_BAD_FIELD_ERROR&#39;,
 errno: 1054,
 sqlState: &#39;42S22&#39;,
 index: 0 }
Error: ER_BAD_FIELD_ERROR: Unknown column &#39;onestairs&#39; in &#39;group statement&#39;
  at Query.Sequence._packetToError (E:\zz\zz_wb123\manage\trunk\code\nod
....

エラーはすべて catch を通じてスローされることがわかります。

つまり、Promise を使用すると、以下にスローされた例外を catch で直接キャッチできます。 queryPromise 関数で例外をログに記録する必要はありません。

関連する推奨事項:

sqlserverデータベースに接続するためのmssqlモジュールに基づくnodejsの単純なカプセル化操作の分析例

TP5データベース操作

mysqlとphpを接続するためのjavascriptでodbc経由で任意のデータベースに接続インスタンスの共有

以上がNodeJs データベース例外処理の分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。