Node.js 連接mysql數據庫問題
問題描述
問題描述: 最近在玩node.js連接mysql數據庫,也連接成功,可以增刪改了。但是有一個問題,每當拋出異常時,我的程序自動停止???并且報以下錯誤:
events.js:160 throw er; // Unhandled ’error’ event ^Error: Connection lost: The server closed the connection. at Protocol.end (D:SoftWareZBJWORKSPACEWebStormWKnode-log-regnode_modulesmysqllibprotocolProtocol.js:109:13) at Socket.<anonymous> (D:SoftWareZBJWORKSPACEWebStormWKnode-log-regnode_modulesmysqllibConnection.js:109:28) at emitNone (events.js:91:20) at Socket.emit (events.js:185:7) at endReadableNT (_stream_readable.js:974:12) at _combinedTickCallback (internal/process/next_tick.js:74:11) at process._tickCallback (internal/process/next_tick.js:98:9)
很奇怪為什么自動停止程序?我的連接數據庫程序如下:
var mysql = require(’mysql’);var db_config = { host: ’127.0.0.1’, port:’3306’, user: ’root’, password: ’root’, database: ’test’};function connectServer() { var client = mysql.createConnection(db_config); return client;}function selectFun(client, username, callback) { //console.log('查詢參數:'+username); //client為一個mysql連接對象 client.query(’select * from user where name='’ + username + ’'’, function (err, results, fields) { // console.log('查詢結果:'+results);if (err) throw err;callback(results); });}function insertFun(client, username, password, callback) { var usr = {name:username,pwd:password}; client.query(’insert into user set ?’, usr, function (err, result) {if (err) { console.log('error:' + err.message); return err;}callback(result); });}exports.connect = connectServer;exports.selectFun = selectFun;exports.insertFun = insertFun;
問題解答
回答1:不要在回調函數中拋出異常,需要使用nodejs的方式:
callback(e,result,...);回調函數的第一個參數為Error對象,如果沒發生錯誤,傳入null
相關文章:
1. html5 - 有可以一次性把所有 css外部樣式轉為html標簽內style=" "的方法嗎?2. sql語句 - mysql中關聯表查詢問題3. javascript - 原生canvas中如何獲取到觸摸事件的canvas內坐標?4. javascript - [js]為什么畫布里不出現圖片呢?在線等5. javascript - vscode alt+shift+f 格式化js代碼,通不過eslint的代碼風格檢查怎么辦。。。6. javascript - 如何將一個div始終固定在某個位置;無論屏幕和分辨率怎么變化;div位置始終不變7. html - vue項目中用到了elementUI問題8. javascript - iframe 為什么加載網頁的時候滾動條這樣顯示?9. javascript - 求解答:實例對象調用constructor,此時constructor內的this的指向?10. javascript - 有什么比較好的網頁版shell前端組件?
