Node.js系列之連接DB的方法(3)
背景
node.js,有人稱(chēng)之為運(yùn)行在服務(wù)器端的JavaScript。以往我們使用JavaScript時(shí),都是依賴(lài)后端查詢(xún)數(shù)據(jù)庫(kù)并返回?cái)?shù)據(jù),而JavaScript只需要展示即可。問(wèn)題來(lái)了,就不能繞開(kāi)后端直接查詢(xún)數(shù)據(jù)庫(kù)嗎?答案是肯定的。
關(guān)系型——以mysql操作為例
node.js提供了mysql操作的驅(qū)動(dòng)(模塊),如果還未安裝,需要執(zhí)行 npm install mysql 命令來(lái)安裝。
//引入模塊
var mysql=require('mysql');
//定義連接對(duì)象connection
var connection=mysql.createConnection({
host:'192.168.*.*',
user:'root',
password:'******',
database:'DB'
});
//連接
connection.connect();
//執(zhí)行查詢(xún)測(cè)試
var sql='select * from sys_user';
connection.query(sql,function(err,result){
if(err){
console.log('[select error]-',err.message);
return;
}
console.log('-----select-------');
console.log(result);
console.log('------------------------');
});
//關(guān)閉連接
connection.end();
部分查詢(xún)結(jié)果如下:

node.js連接mysql的其他增刪改操作就不一一展示了,和查詢(xún)操作類(lèi)似,準(zhǔn)備好sql語(yǔ)句,使用提供的響應(yīng)的方法就ok了。
非關(guān)系型——以mongoDB為例
安裝驅(qū)動(dòng)模塊
npm install mongodb
插入操作
var MongoClient = require('mongodb').MongoClient;
var DB_CONN_STR = 'mongodb://192.168.*.*:27017/runoob';
var insertData = function(db, callback) {
// 連接到表 site
var collection = db.collection('site');
// 準(zhǔn)備數(shù)據(jù)
var data = [{"name":"Sherry","sex":"female","email":"xxxxx@163.com"},{"name":"Tom","sex":"male","email":"xxxx@163.com"}];
collection.insert(data, function(err, result) {
if(err)
{
console.log('Error:'+ err);
return;
}
callback(result);
});
}
MongoClient.connect(DB_CONN_STR, function(err, db) {
console.log("連接成功!");
insertData(db, function(result) {
console.log(result);
db.close();
});
});
執(zhí)行代碼:

可以看到插入日志

使用命令mongodb/bin/mongo進(jìn)入mongo客戶端,可以看到剛剛插入的數(shù)據(jù)。

總結(jié)
從操作來(lái)看,node.js操作數(shù)據(jù)庫(kù)還是比較簡(jiǎn)單的,底層實(shí)現(xiàn)依賴(lài)封裝的mysql/mongodb模塊。
從場(chǎng)景來(lái)看,node.js雖然可以實(shí)現(xiàn)大多數(shù)應(yīng)用的功能,但并非要替代其他技術(shù)或產(chǎn)品,而是針對(duì)不同情況做出適合的選擇。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- node.js操作mongoDB數(shù)據(jù)庫(kù)示例分享
- node.js連接mongoDB數(shù)據(jù)庫(kù) 快速搭建自己的web服務(wù)
- 利用Vue.js+Node.js+MongoDB實(shí)現(xiàn)一個(gè)博客系統(tǒng)(附源碼)
- Node.js中使用mongoskin操作mongoDB實(shí)例
- AngularJS + Node.js + MongoDB開(kāi)發(fā)的基于高德地圖位置的通訊錄
- 安裝使用Mongoose配合Node.js操作MongoDB的基礎(chǔ)教程
- Node.js對(duì)MongoDB數(shù)據(jù)庫(kù)實(shí)現(xiàn)模糊查詢(xún)的方法
- Node.js Mongodb 密碼特殊字符 @的解決方法
- Node.js和MongoDB實(shí)現(xiàn)簡(jiǎn)單日志分析系統(tǒng)
- 利用node.js+mongodb如何搭建一個(gè)簡(jiǎn)單登錄注冊(cè)的功能詳解
相關(guān)文章
node.js文件系統(tǒng)之文件寫(xiě)入實(shí)例詳解
Node.js和其他語(yǔ)言一樣,也有文件操作,下面這篇文章主要給大家介紹了關(guān)于node.js文件系統(tǒng)之文件寫(xiě)入的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03
說(shuō)說(shuō)node中的可讀流和可寫(xiě)流的區(qū)別
這篇文章主要介紹了說(shuō)說(shuō)node中的可讀流和可寫(xiě)流的區(qū)別,詳細(xì)的介紹了可讀流和可寫(xiě)流,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06
node.js利用mongoose獲取mongodb數(shù)據(jù)的格式化問(wèn)題詳解
這篇文章主要給大家介紹了關(guān)于node.js利用mongoose獲取mongodb數(shù)據(jù)的格式化問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)把。2017-10-10
node.js使用redis儲(chǔ)存session的方法
這篇文章主要介紹了node.js使用redis儲(chǔ)存session的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09
Node.js上傳文件功能之服務(wù)端如何獲取文件上傳進(jìn)度
這篇文章主要介紹如何利用progress-stream獲取文件上傳進(jìn)度,以及該組件使用過(guò)程中的注意事項(xiàng)2018-02-02
輕松創(chuàng)建nodejs服務(wù)器(4):路由
這篇文章主要介紹了輕松創(chuàng)建nodejs服務(wù)器(4):路由,服務(wù)器需要根據(jù)不同的URL或請(qǐng)求來(lái)執(zhí)行不一樣的操作,我們可以通過(guò)路由來(lái)實(shí)現(xiàn)這個(gè)步驟,需要的朋友可以參考下2014-12-12
詳解Node.js?應(yīng)用高?CPU?占用率分析方法
這篇文章主要為大家介紹了Node.js?應(yīng)用高?CPU?占用率分析方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10

