溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

nodejs中如何連接數(shù)據(jù)庫

發(fā)布時(shí)間:2021-07-20 11:39:40 來源:億速云 閱讀:998 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了nodejs中如何連接數(shù)據(jù)庫,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

 nodejs連接mysql

1.準(zhǔn)備工作

在nodejs中沒有mysql模塊,但npm中提供了mysql,所以可以使用npm安裝mysql

命令:npm install mysql, 會(huì)生成 node_modules 文件夾 ,如圖

nodejs中如何連接數(shù)據(jù)庫

執(zhí)行后發(fā)現(xiàn)報(bào)了一個(gè)警告,說沒有package.json 這個(gè)文件,只需要執(zhí)行 npm init -f 的命令就會(huì)生成一個(gè)這個(gè)文件

nodejs中如何連接數(shù)據(jù)庫

2.直接連接數(shù)據(jù)庫

mysql.createConnection(Object) 方法與 mysql.createPool(Object)的參數(shù)

host連接數(shù)據(jù)庫所在的主機(jī)名. (默認(rèn): localhost)
port連接端口. (默認(rèn): 3306)
localAddress用于TCP連接的IP地址. (可選)
socketPath鏈接到unix域的路徑。在使用host和port時(shí)該參數(shù)會(huì)被忽略.
userMySQL用戶的用戶名.
passwordMySQL用戶的密碼.
database鏈接到的數(shù)據(jù)庫名稱 (可選).
charset連接的字符集. (默認(rèn): 'UTF8_GENERAL_CI'.設(shè)置該值要使用大寫!)
timezone儲(chǔ)存本地時(shí)間的時(shí)區(qū). (默認(rèn): 'local')
stringifyObjects是否序列化對(duì)象. See issue #501. (默認(rèn): 'false')
insecureAuth是否允許舊的身份驗(yàn)證方法連接到數(shù)據(jù)庫實(shí)例. (默認(rèn): false)
typeCast確定是否講column值轉(zhuǎn)換為本地JavaScript類型列值. (默認(rèn): true)
queryFormat自定義的查詢語句格式化函數(shù).
supportBigNumbers數(shù)據(jù)庫處理大數(shù)字(長(zhǎng)整型和含小數(shù)),時(shí)應(yīng)該啟用 (默認(rèn): false).
bigNumberStrings啟用 supportBigNumbers和bigNumberStrings 并強(qiáng)制這些數(shù)字以字符串的方式返回(默認(rèn): false).
dateStrings強(qiáng)制日期類型(TIMESTAMP, DATETIME, DATE)以字符串返回,而不是一javascript Date對(duì)象返回. (默認(rèn): false)
debug是否開啟調(diào)試. (默認(rèn): false)
multipleStatements是否允許在一個(gè)query中傳遞多個(gè)查詢語句. (Default: false)
flags鏈接標(biāo)志.

連接數(shù)據(jù)庫

var mysql = require('mysql'); //調(diào)用MySQL模塊
//創(chuàng)建一個(gè)connection
var connection = mysql.createConnection({
 host: '192.168.3.3',  //主機(jī)
 user: 'root',    //MySQL認(rèn)證用戶名
 password: 'x5',  //MySQL認(rèn)證用戶密碼
 database: 'dason_yu',
 port: '3306'     //端口號(hào)
});
//創(chuàng)建一個(gè)connection
connection.connect(function(err){
 if(err){
  console.log('[query] - :'+err);
  return;
 }
 console.log('[connection connect] succeed!');
});
//執(zhí)行sql語句
var userAddSql = 'insert into user (id,name,money) values(?,?,?)';
var param = [3,'ccc',200];
/**
 * 執(zhí)行所有類型的 sql 語句
 * query(sql,arr[],function)
 * @parms: sql:sql語句 arr: 填充站位符的數(shù)組,可以缺省
 *   function: 回調(diào)函數(shù),result: 結(jié)果集,對(duì)象組成的數(shù)組
 */
connection.query(userAddSql,param,function(err,rs){
 if(err){
  console.log('insert err:',err.message);
  return;
 }
 console.log('insert success');
});
//關(guān)閉connection
connection.end(function(err){
 if(err){
  console.log(err.toString());
  return;
 }
 console.log('[connection end] succeed!');
});

3.使用連接池連接數(shù)據(jù)庫

將下面代碼寫到 httpServer.js 文件中

使用在命令行窗口中 node httpServer.js 運(yùn)行

var mysql = require('mysql'); //用于創(chuàng)建數(shù)據(jù)庫連接
var pool = mysql.createPool({// 創(chuàng)建數(shù)據(jù)庫連接池
 host : '127.0.0.1' ,
 user : 'root' ,
 password : 'root' ,
 database : 'dason',
 multipleStatements: true
});
/**
 * 獲取數(shù)據(jù)庫連接
 * @parms: err:異常 connnection:數(shù)據(jù)庫連接對(duì)象
 *
 */
pool.getConnection(function(err,connection){
 if(err){
  console.log(err);
 }
 /**
  * 執(zhí)行所有類型的 sql 語句
  * query(sql,arr[],function)
  * @parms: sql:sql語句 arr: 填充站位符的數(shù)組,可以缺省
  *   function: 回調(diào)函數(shù),result: 結(jié)果集,對(duì)象組成的數(shù)組
  */
 connection.query('SELECT * FROM user',function(err,result){
  console.log(result);
  connection.release();//將連接放回連接池
 });
});

結(jié)果:

[ RowDataPacket { id: 1, name: 'a', email: 'a@123' },
 RowDataPacket { id: 2, name: 'b', email: 'b@123' },
 RowDataPacket { id: 4, name: 'd', email: 'd@123' },
 RowDataPacket { id: 5, name: 'e', email: 'e@123' },
 RowDataPacket { id: 6, name: 'f', email: 'f@123' },
 RowDataPacket { id: 3, name: 'c', email: 'c@123' },
 RowDataPacket { id: 7, name: 'g', email: 'g@123' } ]

4. end() 與 destroy()、release()

end() 接受一個(gè)回調(diào)函數(shù),并且會(huì)在query結(jié)束之后才觸發(fā),如果query出錯(cuò),仍然會(huì)終止鏈接,錯(cuò)誤會(huì)傳遞到回調(diào)函數(shù)中處理。

destroy() 立即終止數(shù)據(jù)庫連接,即使還有query沒有完成,之后的回調(diào)函數(shù)也不會(huì)在觸發(fā)。

release() 將連接放回連接池中。

5.package.json

nodejs中如何連接數(shù)據(jù)庫

npm install express –save
npm install express –save-dev

上面代碼表示單獨(dú)安裝express模塊,

–save參數(shù)表示將該模塊寫入dependencies屬性,

–save-dev表示將該模塊寫入devDependencies屬性。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“nodejs中如何連接數(shù)據(jù)庫”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI