中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Node中怎么連接mysql數據庫

發布時間:2021-07-20 16:39:22 來源:億速云 閱讀:274 作者:Leah 欄目:web開發

Node中怎么連接mysql數據庫,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

npm install --save mysql

使用上述命令安裝完MySQL的模塊后,就可以直接使用了,官網的DOCS里一個簡單的例子如下就可以入門了。

var mysql = require('mysql');
var connection = mysql.createConnection({
 host: 'localhost',
 user: 'me',
 password : 'secret',
 database : 'my_db'
});
connection.connect();
connection.query('SELECT 1 + 1 AS solution', function(err, rows, fields) {
 if (err) throw err;
 console.log('The solution is: ', rows[0].solution);
});
connection.end();

很簡單的一個例子,從上面的例子可以得出:使用createConnection(option)方法創建一個連接對象,然后連接對象的connect()方法創建連接,最后使用query()方法執行SQL語句,返回結果作為回調函數的參數rows返回,rows為數組類型。

1. 連接

創建連接對象,需要傳入連接數據庫的一些連接參數,也就是createConnection(option)里的option,option是一個對象,以鍵值對的形式傳入createConnection()方法里。上例列舉出了最基本的參數:

  • host 主機名

  • user 連接數據庫的用戶

  • password 密碼

  • database 數據庫名稱

還有其他的參數,可以查詢下官方DOCS,這里不一一列舉了,初期學習上面這些參數就足以。

2. 關閉

關閉一個連接使用end()方法,end()方法提供一個回調函數,如下:

connect.end(function(err){
  console.log('End a connection');
});

這是建議使用的方法,end()方法會等待連接回調完成后才關閉連接。官方還提供了另外一種方法destroy()方法,這個方法直接關閉連接,不會等待回調完成。

舉個簡單的例子:

var mysql = require('mysql');
var option = require('./connect.js').option;
var conn = mysql.createConnection(option);
conn.query('select * from message',function(err,rows,fields){
 if(!err){
  console.log(rows);
 }
});
conn.end(function(err){
 console.log('end a connection');
});

最終結果會是:先打印完SELECT數據表結果后,再打印end a connection。而如果你將關閉方法換成conn.destroy();,那么你就別想返回任何結果了,因為還沒等回調結束就已經終止連接了。

3. 連接池

連接池的原理是一開始就給你創建多個連接對象放在一個“池子”里,用的時候取一個,用完了放回“池子”里,在一定程度上是有利于節省系統開銷的,因為連接對象是在最開始的時候就創建好了,使用的時候不再需要系統開銷去創建數據庫連接對象。官方DOCS介紹了連接方法:

var mysql = require('mysql');
var pool = mysql.createPool({
 connectionLimit : 10,
 host      : 'example.org',
 user      : 'bob',
 password    : 'secret',
 database    : 'my_db'
});
pool.query('SELECT 1 + 1 AS solution', function(err, rows, fields) {
 if (err) throw err;
 console.log('The solution is: ', rows[0].solution);
});

創建連接池的方法是createPool(option),option里多了一個參數connectionLimit指的是一次性在連接池里創建多少個連接對象,默認10個。如果你想共享一個連接對象,可以使用下面方法進行連接;

var mysql = require('mysql');
var pool = mysql.createPool({
 host   : 'example.org',
 user   : 'bob',
 password : 'secret',
 database : 'my_db'
});
pool.getConnection(function(err, connection) {
 // Use the connection
 connection.query( 'SELECT something FROM sometable', function(err, rows) {
  // And done with the connection.
  connection.release();
  // Don't use the connection here, it has been returned to the pool.
 });

// Use the connection
 connection.query( 'SELECT something2 FROM sometable2', function(err, rows) {
  // And done with the connection.
  connection.release();
  // Don't use the connection here, it has been returned to the pool.
 });
});

使用一個連接對象執行兩次query()函數。

4. 示例1

使用基本的連接方式來連接數據庫,分別定義數據連接以及關閉的function,如下示例:

// connect.js 數據庫連接與關閉
var mysql = require('mysql');
var config = require('./config.json'); // 將數據庫連接參數寫入mysql對象,即config.mysql
var connCount = 0; // 統計目前未關閉的連接
exports.getConn = function(){
 connCount ++;
 console.log('............................OPEN a connection, has '+ connCount + ' connection.');
 return mysql.createConnection(config.mysql);
};
exports.endConn = function(conn){
 conn.end(function(err){
  if(!err){
   connCount --;
   console.log('.........................CLOSE a connection, has '+ connCount + ' connection.');
  }
 });
};

然后給個使用數據庫的示例,

// db.js 查詢用戶信息
var connect = require('./connect.js'); // 引入數據連接方法
exports.getUser = function(username, callback){
  var connection = connect.getConn();
  var sql = 'select * from user where username = "' + username + '"';
  connection.query(sql,function(err,rows,fields){
    callback(err,rows,fields);  
  });
  connect.endConn(connection);
}

5. 示例2

使用數據庫連接池,同樣先創建數據庫連接池的方法,如下兩種方式:

// connect.js 直接使用
var mysql = require('mysql');
var config = require('./config.json');
var pool = mysql.createPool(config.mysql);

exports.querySQL = function(sql,callback){
  pool.query(sql, function(err,rows,fields){
    callback(err,rows,fields);
  });
}
// connect.js 使用getConnection方法
var mysql = require('mysql');
var config = require('./config.json');
var pool = mysql.createPool(config.mysql);

exports.querySQL = function(sql, callback){
  pool.getConnection(function(err,conn){
    conn.query(sql,function(err,rows,fields){
      callback(err,rows,fields); 
      conn.release();  // 不要忘了釋放
    });    
  });
}

使用的時候,直接使用querySQL方法即可,如下:

// db.js 查詢用戶信息
var connect = require('./connect.js');
exports.getUser = function(username,callback){
  var sql = 'select * from user where username = "' + username + '"';
  connect.querySQL(sql,function(err,rows,fields){
    callback(err,rows,fields);    
  });
};

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南阳市| 霍邱县| 商丘市| 恩施市| 嘉祥县| 永丰县| 镇安县| 崇义县| 富蕴县| 纳雍县| 昌黎县| 炉霍县| 游戏| 孙吴县| 寿光市| 墨玉县| 东乌珠穆沁旗| 麻阳| 阜平县| 连江县| 义乌市| 桓仁| 贡山| 田林县| 三门峡市| 长寿区| 彭山县| 江西省| 嵊州市| 青岛市| 朝阳市| 黄平县| 建德市| 页游| 电白县| 洮南市| 平泉县| 醴陵市| 滦南县| 九台市| 玉山县|