node.js基礎:數據存儲

  無服務器的數據存儲

    內存存儲

var http = require('http');
var count = 0; //服務器訪問次數存儲在內存中
http.createServer(function(req,res){res.write('hello'+ ++count);res.end();
}).listen(3000);    

    基于文件的存儲

    node.js中主要用fs文件系統模塊來管理文件的存儲。

    文件系統模塊是一個簡單包裝的標準 POSIX 文件 I/O 操作方法集。您可以通過調用require('fs')來獲取該模塊。文件系統模塊中的所有方法均有異步和同步版本。

    在繁重的任務中,強烈推薦使用這些函數的異步版本.同步版本會阻塞進程,直到完成處理,也就是說會暫停所有的連接。 

var fs = require('fs');
//讀取一個文件的全部內容
fs.readFile('./node.txt',function(err,data){if(err) throw err;console.log(data); //data就是文件的內容
});
//將數據寫入一個文件, 如果文件原先存在,會被替換。 data 可以是一個string,也可以是一個原生buffer。
fs.writeFile('./node.txt','hello','utf8',function(err) {if(err) throw err;console.log('Saved');
});

  數據庫管理系統(DBMS)

    關系型數據庫:MySQLPostgreSQL

    NoSQL數據庫:RedisMongoDBMongoose

  MySQL

  使用第三方mysql模塊讓node.js跟MySQL交互

npm install mysql

  設置數據庫

//引入mysql模塊
var mysql = require('mysql');
//設置數據庫
var db = mysql.createConnection({host:     '127.0.0.1',user:     'root',password: '123456',database: 'shop' //數據庫名稱
});
db.connect();
//查詢數據
db.query('select * from tb_user',function(err,rows,fields){if(err) throw err;console.log( rows[0].tel ); //rows為查詢到的數據集數組
});
db.end();

?  MongoDB

   安裝

npm install mongodb

?  連接MongoDB

var mongodb = require('mongodb');
var server = new mongodb.Server('127.0.0.1', 27017, {});
var client = new mongodb.Db('mydatabase', server, {w: 1});

?  訪問MongoDB集合

client.open(function(err){if(err) throw err;client.collection('test_insert', function(err, collection){if(err) throw err;//..});
});

?  將文檔插入集合中

collection.insert({"title": "I like cake","body": "It is quite good."
},{safe: true }, function(err, documents) {if(err) throw err;console.log('Document ID is: ' + documents[0]._id);
});

?  用文檔ID更新數據

var _id = new client.bson_serializer .ObjectID('4e650d344ac74b5a01000001');
collection.update({_id: _id},{$set:{"title": "I ate too much cake"}},{safe: true},function(err){if (err) throw err;
});

?  搜索文檔

collection.find({"title": "I ate too much cake"}).toArray(function(err,results){if(err) throw err;console.log(results);
});

?  刪除文檔

var _id = new client.bson_serializer.ObjectID('4e650d344ac74b5a01000001');
collection.remove({_id: _id},{safe:true},function(err){if(err) throw err;
});

?  Mongoose

  ?Mongoose是一個抽象的MongoDB數據庫訪問API,在底層處理細節,可以加快開發速度,同時維護更少的代碼。

npm install mongoose

?  連接的打開和關閉

//連接
var mongoose = require('mongoose');
var db = mongoose.connect('mongodb://localhost/tasks'); //tasks為數據庫
//打開
mongoose.disconnect();

?  注冊schema

var Schema = mongoose.Schema;
var Tasks = new Schema({project: String,description: String
});
mongoose.model('Task', Tasks);

?  添加任務

var Task = mongoose.model('Task');
var task = new Task();
task.project = 'Bikeshed';
task.description = 'Paint the bikeshed red.';
task.save(function(err) {if (err) throw err;console.log('Task saved.');
});

?  搜索文檔

var Task = mongoose.model('Task');
Task.find({'project': 'Bikeshed'}, function(err, tasks) {for (var i = 0; i < tasks.length; i++) {console.log('ID:' + tasks[i]._id);console.log(tasks[i].description);}
});

?  更新文檔

var Task = mongoose.model('Task');
Task.update({_id: '4e650d344ac74b5a01000001'},{description:'Paint the bikeshed green.'},{multi:false},function(err,rows_updated){if (err) throw err;console.log('Updated.');
});

?  刪除文檔

var Task = mongoose.model('Task');
Task.findById('4e650d344ac74b5a01000001',function(err,task){task.remove();
});

?  如果喜歡基于SQL的處理方式,關系型數據庫管理系統MySQL和PostgreSQL都得到了很好的支持。

  如果發現SQL在性能或靈活性上表現欠佳,Redis和MongoDB都是不錯的可選項。MongoDB是極佳的通用DBMS,而Redis擅長處理變化頻繁,相對比較簡單的數據。

轉載于:https://www.cnblogs.com/eyeear/p/4744130.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/375610.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/375610.shtml
英文地址,請注明出處:http://en.pswp.cn/news/375610.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

CUDA 6.5 VS2013 Win7:創建CUDA項目

運行環境&#xff1a; Win7VS2013CUDA6.5 1.創建win32空項目 2.右鍵項目解決方案-->生成項目依賴項-->生成自定義 3.右鍵項目解決方案-->屬性-->配置屬性-->常規-->平臺工具集 配置屬性-->VC目錄-->包含目錄&#xff0c;添加 $(CUDA_INC_PATH) 連接器-…

c/c++編碼規范(2)--作用域

2. 作用域 靜止使用class類型的靜態或全局變量。 6. 命名約定 6.1. 函數名&#xff0c;變量名&#xff0c;文件名要有描述性&#xff0c;少用縮寫。 6.2. 文件命名 6.2.1. 文件名要全部用小寫。可使用“_”或"-"&#xff0c;遵從項目規范&#xff0c;沒有規范&#x…

subversion svnserver服務啟動與配置

svnserve 是一個輕量級的服務&#xff0c; 使用自定義的協議通過TCP/IP與客戶端通訊。 客戶端通過由 svn:// 或者 svnssh:// 開始的URL訪問svnserve服務器。 啟動服務器 端口監控&#xff08;inetd&#xff09;模式 如果你打算用端口監控來啟動處理客戶的訪問請求的進程&#x…

mongodb地理空間索引原理閱讀摘要

http://www.cnblogs.com/taoweiji/p/3710495.html 具體原理在上面 簡單概述&#xff0c;&#xff08;x,y&#xff09;經緯度坐標&#xff0c;通過geohash的方式&#xff0c;通過N次方塊四分割生成一個坐標碼&#xff0c;然后用坐標碼進行BTREE的索引建立轉載于:https://www.cnb…

angular 頁面加載時可以調用 函數處理

轉載于 作者:海底蒼鷹地址:http://blog.51yip.com/jsjquery/1599.html 我希望頁面加載的時候&#xff0c;我能馬上處理頁面的數據&#xff0c;如請求API .... 所以這樣設置 在某個頁面的控制器中 監聽頁面load phonecatControllers.controller(registerctr, [$scope, $routePa…

刪除排序數組中的重復項

給定一個排序數組&#xff0c;你需要在原地刪除重復出現的元素&#xff0c;使得每個元素只出現一次&#xff0c;返回移除后數組的新長度。 不要使用額外的數組空間&#xff0c;你必須在原地修改輸入數組并在使用 O(1) 額外空間的條件下完成。 示例 1: 給定數組 nums [1,1,2…

android 處理鼠標滾輪事件 【轉】

android處理鼠標滾輪事件&#xff0c;并不是如下函數&#xff1a; 1&#xff09; public boolean onKeyDown(int keyCode, KeyEvent event) 2) public boolean dispatchKeyEvent(KeyEvent event) 3) public boolean onTouchEvent(MotionEvent event) 而是如下函數 …

ASP.NET數據報表之柱狀圖 ------工作日志

#region 柱形色調 /// <summary> /// 柱形色調 /// </summary> private string[] myColor new string[] { "DarkGreen", "DimGray", "DodgerBlue", "Orchid", //Peru "Orange", "Orchid", &q…

接口安全--簽名驗證

為防止第三方冒充客戶端請求服務器&#xff0c;可以采用參數簽名驗證的方法&#xff1a; 將請求參數中的各個鍵值對按照key的字符串順序升序排列&#xff08;大小寫敏感&#xff09;&#xff0c;把key和value拼成一串之后最后加上密鑰&#xff0c;組成key1value1key2value2PRIV…

Runtime類

Runtime類也在java.lang包中&#xff0c;這個類沒有提供構造器&#xff0c;但是提供的卻非靜態方法&#xff0c;而是在方法中提供了一個靜態方法來返回當前進程的Runtime實例&#xff0c;采用的單例設計模式。 其作用&#xff1a;可以對當前java程序進程進行操作、打開本機程序…

Spring MVC 返回NULL時客戶端用$.getJSON的問題

如果Spring MVC返回是NULL&#xff0c;那么客戶端的$.getJSON就不會觸發&#xff1b; 20170419補充 后臺的輸出為&#xff1a; DEBUG [org.springframework.web.servlet.DispatcherServlet] - Null ModelAndView returned to DispatcherServlet with name springMVC: assuming …

duilib設置滾動條自動滾動到底

控件屬性中添加 vscrollbar"true" autovscroll"true"分別是啟用豎向滾動條&#xff0c;是否隨輸入豎向滾動

MVC,MVP 和 MVVM 的圖示

復雜的軟件必須有清晰合理的架構&#xff0c;否則無法開發和維護。 MVC&#xff08;Model-View-Controller&#xff09;是最常見的軟件架構之一&#xff0c;業界有著廣泛應用。它本身很容易理解&#xff0c;但是要講清楚&#xff0c;它與衍生的 MVP 和 MVVM 架構的區別就不容易…

Java JDBC學習實戰(二): 管理結果集

在我的上一篇博客《Java JDBC學習實戰&#xff08;一&#xff09;&#xff1a; JDBC的基本操作》中&#xff0c;簡要介紹了jdbc開發的基本流程&#xff0c;并詳細介紹了Statement和PreparedStatement的使用&#xff1a;利用這兩個API可以執行SQL語句&#xff0c;完成基本的CURD…

error: storage size of ‘threads’ isn’t known

出錯的代碼行&#xff1a; pthread_t threads[NUM_THREADS];原因&#xff1a; NUM_THREADS 無值 原先&#xff1a; #define NUM_THREADS修改為 #define NUM_THREADS 5

android之相機開發

http://blog.csdn.net/jason0539/article/details/10125017 android之相機開發 分類&#xff1a; android 基礎知識2013-08-20 22:32 9774人閱讀 評論(2) 收藏 舉報Android在android中應用相機功能&#xff0c;一般有兩種&#xff1a;一種是直接調用系統相機&#xff0c;一種自…

文件和文件夾權限-Win7公共盤中出現大量臨時文件

公司中有一個文件服務器&#xff0c;給不同部門和員工設置了不同的權限&#xff0c;最近有員工&#xff08;沒有修改權限&#xff0c;有讀取及執行,讀取,寫入&#xff09;反映在公共盤上修改文件的時候會產生大量的臨時文件&#xff0c;添加上修改權限之后就可以了&#xff0c;…

Duilib編輯框Edit輸入完自動跳到下一個編輯框

首先xml文件中設置edit的maxchar參數&#xff0c;默認255好像。 <edit maxchar"10" />然后在notify函數中加入以下代碼 if (msg.sType _T("textchanged")) {if (static_cast<CEditUI*>(msg.pSender)->GetMaxChar() msg.pSender->GetT…

Mysql數據庫安全管理配置

1.刪除test庫 原因&#xff1a; The default MySQL installation comes with a database named test that anyone can access. This database is intended only for tutorials, samples, testing, etc. Databases named "test" and also databases with names starti…

duilib清空richedit內容

推薦使用以下方法&#xff1a; m_pRichEdit->SetSelAll(); m_pRichEdit->Clear();不推薦使用以下方法&#xff1a; m_pRichEdit->SetText("");雖然效果是一樣的&#xff0c;但是當編輯框中文本存在多種格式的時候&#xff0c;第二種方法會存在問題&#x…