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

nodejs進(jìn)階(6)—連接MySQL數(shù)據(jù)庫(kù)示例

 更新時(shí)間:2017年01月07日 16:01:29   作者:方帥  
本篇文章主要介紹了nodejs進(jìn)階(6)—連接MySQL數(shù)據(jù)庫(kù)示例,詳細(xì)的介紹了NodeJS操作MySQL數(shù)據(jù)庫(kù),作為應(yīng)用最為廣泛的開(kāi)源數(shù)據(jù)庫(kù)則成為我們的首選,有興趣的可以了解一下。

1. 建庫(kù)連庫(kù)

連接MySQL數(shù)據(jù)庫(kù)需要安裝支持

npm install mysql

我們需要提前安裝按mysql sever端

建一個(gè)數(shù)據(jù)庫(kù)mydb1

mysql> CREATE DATABASE mydb1;
mysql> SHOW DATABASES;
+--------------------+
| Database      |
+--------------------+
| information_schema |
| mysql       |
| mydb1       |
| performance_schema |
+--------------------+
4 rows in set (0.00 sec) 

然后建一張表user如下

create table user( 
id int not null primary key auto_increment, 
name VARCHAR(100) not null, 
pwd VARCHAR(100) not null,
create_date TIMESTAMP NULL DEFAULT now()
)ENGINE=InnoDB DEFAULT CHARSET=utf8; 
CREATE UNIQUE INDEX t_quiz_IDX_0 on user(name); 

接下來(lái)我們利用nodejs連接mysql數(shù)據(jù)庫(kù)

var mysql = require('mysql'); //調(diào)用MySQL模塊
//創(chuàng)建一個(gè)connection 
var connection = mysql.createConnection({   
  host: 'localhost',    //主機(jī) 
  user: 'root',        //MySQL認(rèn)證用戶(hù)名 
  password: 'root',    //MySQL認(rèn)證用戶(hù)密碼 
  database: 'mydb1', 
  port: '3306'          //端口號(hào) 
});
//創(chuàng)建一個(gè)connection 
connection.connect(function(err){ 
  if(err){     
    console.log('[query] - :'+err); 
    return; 
  } 
  console.log('[connection connect] succeed!'); 
}); 
//----插入
var userAddSql = 'insert into user (name,pwd) values(?,?)';
var param = ['fff','123'];
connection.query(userAddSql,param,function(err,rs){
  if(err){
    console.log('insert err:',err.message);
    return;
  }
    console.log('insert success');
});
//執(zhí)行查詢(xún) 
connection.query('SELECT * from user where id=?',[2], function(err, rs) { 
  if (err) { 
    console.log('[query] - :'+err); 
    return; 
  } 
  for(var i=0;i<rs.length;i++){
    console.log('The solution is: ', rs[i].uname); 
  }
});  

//關(guān)閉connection 
connection.end(function(err){ 
  if(err){ 
    console.log(err.toString());
    return; 
  } 
  console.log('[connection end] succeed!'); 
});

但是實(shí)際每次創(chuàng)建連接都需要一定的開(kāi)銷(xiāo),執(zhí)行效率就會(huì)有影響。下面介紹一種連接池連mysql的方法:node-mysql

2. 連接池配置使用

node-mysql是目前最火的node下的mysql驅(qū)動(dòng),是mysqlpool的一個(gè)模塊。

下面的代碼是提供一個(gè)連接池,getPool函數(shù)返回createPool創(chuàng)建的數(shù)據(jù)庫(kù)連接池對(duì)象。 

var mysql = require('mysql'); //調(diào)用MySQL模塊 
function OptPool(){ 
  this.flag=true; //是否連接過(guò) 
  this.pool = mysql.createPool({   
    host: 'localhost',    //主機(jī) 
    user: 'root',        //MySQL認(rèn)證用戶(hù)名 
    password: 'root',    //MySQL認(rèn)證用戶(hù)密碼 
    database: 'test', 
    port: '3306'          //端口號(hào) 
  }); 
 
  this.getPool=function(){ 
     return this.pool; 
  } 
}; 
module.exports = OptPool;

下面的代碼展示如何使用這個(gè)連接池,插入和查詢(xún)的使用。需要注意的是conn.release(); //釋放一個(gè)連接放回連接池 需要再操作結(jié)束后再執(zhí)行,否則后面的數(shù)據(jù)庫(kù)操作會(huì)報(bào)錯(cuò)。

var OptPool = require('./models/OptPool'); 
 
var optPool = new OptPool(); 
var pool = optPool.getPool(); 

//執(zhí)行SQL語(yǔ)句 
//從連接池中獲取一個(gè)連接
pool.getConnection(function(err,conn){ 
  //----插入 
  var userAddSql = 'insert into user (uname,pwd) values(?,?)'; 
  var param = ['eee','eee'];
  conn.query(userAddSql,param,function(err,rs){
    if(err){ 
      console.log('insert err:',err.message); 
      return; 
    } 
    console.log('insert success'); 
    //conn.release(); //放回連接池
  })
  //查詢(xún) 
  conn.query('SELECT * from user', function(err, rs) { 
    if (err) { 
      console.log('[query] - :'+err); 
      return; 
    }  
    for(var i=0;i<rs.length;i++){
      console.log(rs[i].uname); 
    }
    conn.release(); //放回連接池
  });
});

下面介紹一個(gè)復(fù)雜一點(diǎn)的增刪查改的數(shù)據(jù)庫(kù)操作,因相互之間有依賴(lài),所以代碼可讀性就變得特別差。

var OptPool = require('./models/OptPool'); 
 
var optPool = new OptPool(); 
var pool = optPool.getPool(); 

var insertSQL = 'insert into table1(name,pwd) values("conan","123"),("fens.me","456")';
var selectSQL = 'select * from table1 limit 10';
var deleteSQL = 'delete from table1';
var updateSQL = 'update table1 set name="conan update" where name="conan"';

pool.getConnection(function(err,conn){ 
//delete
  conn.query(deleteSQL, function (err0, res0) {
    if (err0) console.log(err0);
    console.log("DELETE Return ==> ");
    console.log(res0);

    //insert
    conn.query(insertSQL, function (err1, res1) {
      if (err1) console.log(err1);
      console.log("INSERT Return ==> ");
      console.log(res1);

      //query
      conn.query(selectSQL, function (err2, rows) {
        if (err2) console.log(err2);

        console.log("SELECT ==> ");
        for (var i in rows) {
          console.log(rows[i]);
        }

        //update
        conn.query(updateSQL, function (err3, res3) {
          if (err3) console.log(err3);
          console.log("UPDATE Return ==> ");
          console.log(res3);

          //query
          conn.query(selectSQL, function (err4, rows2) {
            if (err4) console.log(err4);

            console.log("SELECT ==> ");
            for (var i in rows2) {
              console.log(rows2[i]);
            }
          });
        });
      });
    });
  });
})

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解如何使用Node.js連接數(shù)據(jù)庫(kù)ORM

    詳解如何使用Node.js連接數(shù)據(jù)庫(kù)ORM

    這篇文章主要為大家介紹了詳解如何使用Node.js連接數(shù)據(jù)庫(kù)ORM示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • node作為中間服務(wù)層如何發(fā)送請(qǐng)求(發(fā)送請(qǐng)求的實(shí)現(xiàn)方法詳解)

    node作為中間服務(wù)層如何發(fā)送請(qǐng)求(發(fā)送請(qǐng)求的實(shí)現(xiàn)方法詳解)

    node作為中間服務(wù)層如何發(fā)送請(qǐng)求?下面小編就為大家分享一下發(fā)送請(qǐng)求的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助
    2018-01-01
  • windows 下安裝nodejs 環(huán)境變量設(shè)置

    windows 下安裝nodejs 環(huán)境變量設(shè)置

    windows 下安裝nodejs 了,也安裝了npm, 但是有時(shí)候切不能直接用request(‘ws’)這一類(lèi)的東西.我覺(jué)得是確實(shí)環(huán)境變量或其他設(shè)置有問(wèn)題,能否給個(gè)完整的設(shè)置方案:
    2017-02-02
  • Node.js?操作本地文件及深入了解fs內(nèi)置模塊

    Node.js?操作本地文件及深入了解fs內(nèi)置模塊

    這篇文章主要介紹了Node.js?操作本地文件及深入了解fs內(nèi)置模塊,node.js作為服務(wù)端應(yīng)用,肯定少不了對(duì)本地文件的操作,像創(chuàng)建一個(gè)目錄、創(chuàng)建一個(gè)文件、讀取文件內(nèi)容等都是我們開(kāi)發(fā)中經(jīng)常需要用到的功能
    2022-09-09
  • Nodejs excel(.xlsx) 文件的讀寫(xiě)方式

    Nodejs excel(.xlsx) 文件的讀寫(xiě)方式

    這篇文章主要介紹了Nodejs excel(.xlsx) 文件的讀寫(xiě)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • node?gyp安裝canvas原生模塊編譯node?pregyp詳解

    node?gyp安裝canvas原生模塊編譯node?pregyp詳解

    這篇文章主要為大家介紹了Nodejs關(guān)于原生模塊編譯node-gyp + node-pre-gyp (以安裝canvas為例)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • nodejs中轉(zhuǎn)換URL字符串與查詢(xún)字符串詳解

    nodejs中轉(zhuǎn)換URL字符串與查詢(xún)字符串詳解

    這篇文章主要介紹了nodejs中轉(zhuǎn)換URL字符串與查詢(xún)字符串詳解,需要的朋友可以參考下
    2014-11-11
  • Nodejs處理Json文件并將處理后的數(shù)據(jù)寫(xiě)入新文件中

    Nodejs處理Json文件并將處理后的數(shù)據(jù)寫(xiě)入新文件中

    這篇文章主要介紹了Nodejs處理Json文件并將處理后的數(shù)據(jù)寫(xiě)入新文件中,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • node.js的http.createServer過(guò)程深入解析

    node.js的http.createServer過(guò)程深入解析

    這篇文章主要給大家介紹了關(guān)于node.js的http.createServer過(guò)程的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用node.js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 使用Node.js構(gòu)建微服務(wù)的方法

    使用Node.js構(gòu)建微服務(wù)的方法

    這篇文章主要介紹了使用Node.js構(gòu)建微服務(wù),將介紹微服務(wù)架構(gòu)、優(yōu)勢(shì)以及如何使用Node.js開(kāi)發(fā)微服務(wù),需要的朋友可以參考下
    2022-08-08

最新評(píng)論