欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

nodejs入門教程五:連接數(shù)據庫的方法分析

 更新時間:2017年04月24日 11:36:10   作者:Dason_yu  
這篇文章主要介紹了nodejs入門教程之連接數(shù)據庫的方法,結合實例形式分析了nodejs連接數(shù)據庫的具體步驟與相關操作技巧,需要的朋友可以參考下

本文實例講述了nodejs入門教程之連接數(shù)據庫的方法。分享給大家供大家參考,具體如下:

參考文章鏈接:  nodejs連接mysql

1.準備工作

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

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

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

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

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

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

連接數(shù)據庫

var mysql = require('mysql'); //調用MySQL模塊
//創(chuàng)建一個connection
var connection = mysql.createConnection({
 host: '192.168.3.3',  //主機
 user: 'root',    //MySQL認證用戶名
 password: 'x5',  //MySQL認證用戶密碼
 database: 'dason_yu',
 port: '3306'     //端口號
});
//創(chuàng)建一個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: 回調函數(shù),result: 結果集,對象組成的數(shù)組
 */
connection.query(userAddSql,param,function(err,rs){
 if(err){
  console.log('insert err:',err.message);
  return;
 }
 console.log('insert success');
});
//關閉connection
connection.end(function(err){
 if(err){
  console.log(err.toString());
  return;
 }
 console.log('[connection end] succeed!');
});

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

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

使用在命令行窗口中 node httpServer.js 運行

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

結果:

[ 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() 接受一個回調函數(shù),并且會在query結束之后才觸發(fā),如果query出錯,仍然會終止鏈接,錯誤會傳遞到回調函數(shù)中處理。

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

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

5.package.json

npm install express –save

npm install express –save-dev

上面代碼表示單獨安裝express模塊,

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

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

希望本文所述對大家nodejs程序設計有所幫助。

相關文章

  • 使用Koa實現(xiàn)一個獲取視頻播放地址的接口

    使用Koa實現(xiàn)一個獲取視頻播放地址的接口

    在本節(jié)課中,我們將學習如何使用 Koa 實現(xiàn)一個獲取視頻播放地址的接口,我們將創(chuàng)建一個控制器,通過視頻 ID 獲取播放地址,并設置相應的路由,最后,我們將使用 Postman 進行測試,感興趣的朋友可以參考下
    2024-05-05
  • Node.js 的異步 IO 性能探討

    Node.js 的異步 IO 性能探討

    Node.js 的賣點是「異步單線程」,雖然主流 Web 后端編程語言中,對異步編程有很好支持的語言并不少,但只有 Node.js 喪心病狂地將所有 IO 強制異步進行。
    2014-10-10
  • nodejs實現(xiàn)截取上傳視頻中一幀作為預覽圖片

    nodejs實現(xiàn)截取上傳視頻中一幀作為預覽圖片

    這篇文章主要為大家詳細介紹了nodejs實現(xiàn)截取上傳視頻中一幀作為預覽圖片,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • Node.js編寫爬蟲的基本思路及抓取百度圖片的實例分享

    Node.js編寫爬蟲的基本思路及抓取百度圖片的實例分享

    這篇文章主要介紹了Node.js編寫爬蟲的基本思路及抓取百度圖片的實例分享,其中作者提到了需要特別注意GBK轉碼的轉碼問題,需要的朋友可以參考下
    2016-03-03
  • 詳解nodejs微信公眾號開發(fā)——2.自動回復

    詳解nodejs微信公眾號開發(fā)——2.自動回復

    這篇文章主要介紹了詳解nodejs微信公眾號開發(fā)——2.自動回復,非常具有實用價值,需要的朋友可以參考下
    2017-04-04
  • Node.js、Socket.IO和GPT-4構建AI聊天機器人的項目實踐

    Node.js、Socket.IO和GPT-4構建AI聊天機器人的項目實踐

    本文主要介紹了Node.js、Socket.IO和GPT-4構建AI聊天機器人的項目實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • Nodejs+express+ejs簡單使用實例代碼

    Nodejs+express+ejs簡單使用實例代碼

    本篇文章主要介紹了Nodejs+express+ejs簡單使用實例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • node.js中的fs.truncateSync方法使用說明

    node.js中的fs.truncateSync方法使用說明

    這篇文章主要介紹了node.js中的fs.truncateSync方法使用說明,本文介紹了fs.truncateSync的方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • koa2的中間件功能及應用示例

    koa2的中間件功能及應用示例

    這篇文章主要介紹了koa2的中間件功能及應用示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • nodejs連接mysql數(shù)據庫簡單封裝示例-mysql模塊

    nodejs連接mysql數(shù)據庫簡單封裝示例-mysql模塊

    本篇文章主要介紹了nodejs連接mysql數(shù)據庫簡單封裝(mysql模塊),具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2017-04-04

最新評論