无服务器的数据存储

    内存存储

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擅长处理变化频繁,相对比较简单的数据。

node.js基础:数据存储的更多相关文章

  1. 进击Node.js基础(二)

    一.一个牛逼闪闪的知识点Promise npm install bluebird 二.Promise实例 ball.html <!doctype> <!DOCTYPE html> ...

  2. node.js基础模块http、网页分析工具cherrio实现爬虫

    node.js基础模块http.网页分析工具cherrio实现爬虫 一.前言      说是爬虫初探,其实并没有用到爬虫相关第三方类库,主要用了node.js基础模块http.网页分析工具cherri ...

  3. Node.js基础与实战

    Node.js基础与实战 Node.jsJS高级进阶 NODE原理与解析 REPL交互环境 模块与NPM Buffer缓存区 fs文件操作 Stream流 TCP&UDP 异步编程 HTTP& ...

  4. Node.js基础知识

    Node.js入门   Node.js     Node.js是一套用来编写高性能网络服务器的JavaScript工具包,一系列的变化由此开始.比较独特的是,Node.js会假设在POSIX环境下运行 ...

  5. NodeJs>------->>第三章:Node.js基础知识

    第三章:Node.js基础知识 一:Node.js中的控制台 1:console.log.console.info  方法 console.log(" node app1.js 1> ...

  6. 10慕课网《进击Node.js基础(一)》初识promise

    首先用最简单的方式实现一个动画效果 <!doctype> <html> <head> <title>Promise animation</titl ...

  7. 07慕课网《进击Node.js基础(一)》HTTP小爬虫

    获取HTML页面 var http = require('http') var url='http://www.imooc.com/learn/348' http.get(url,function(r ...

  8. 03慕课网《进击Node.js基础(一)》API-URL网址解析

    url url.parse(url,query,host);解析域名 url必须,地址字符串 query可选 host 可选:在不清楚协议时正确解析 querystring 字符串和对象之间互相解析 ...

  9. 01慕课网《进击Node.js基础(一)》Node.js安装,创建例子

    版本:偶数位为稳定版本,基数为非稳定版本 - 0.6.x - 0.7.x    - 0.8.x -0.9.x    -0.10.x  -0.11.x 概念:Node.js采用谷歌浏览器的V8引擎,用C ...

随机推荐

  1. nRF Toolbox 1.2 使用AKII的实现,而Becon始终不好使

    这几天调试使用nRF51822驱动mpu6050及其数据传输到android中,调试的过程遇到一些困难,apptimer不太会用,然后就參考了下ble_app_hrs的程序,结果成功搞定,demo的价 ...

  2. python语言学习7——数据类型和变量

    整数 python可以处理任意大小的整数,包括负整数,在程序中的表示方法和数学上的写法一样 计算机由于使用二进制,有时候采用十六进制表示整数比较方便,十六进制数用0x前缀 浮点数 简单的小数就直接用小 ...

  3. hello MemSQL 入门安装演示样例

    一,介绍 MemSQL号称世界上最快的分布式关系型数据库,兼容mysql但快30倍,能实现每秒150万次事务.原理是仅用内存并将SQL预编译为C++. 二,部署 官网下载地址:http://www.m ...

  4. 你的App为什么上不了TOP10?

     App市场风起云涌.但是,却仅仅有少数几个App能成为"暴发户",很多其它的则沉淀在应用商店中无人问津. 在移动互联网时代.智能手机成为了中心. 手机之所以智能.就在于手机上 ...

  5. HDSF主要节点解说(二)工作原理

    HDFS(Hadoop Distributed File System )Hadoop分布式文件系统. 是依据google发表的论文翻版的.论文为GFS(Google File System)Goog ...

  6. Django Form Media 阅读笔记

    ---恢复内容开始--- Form Media Rendering an attractive and easy-to-use Web form requires more than just HTM ...

  7. cocos2dx手写js绑定C++

    这两天连续查阅了js绑定c++的非常多文章  , 有手动与自己主动两种方式 . 本来想用自己主动绑定的 , 可是NDK一直下载不下来.....就给算了 . 以下总结一下手动绑定的实现过程 : 一共三步 ...

  8. Knockout应用开发指南 第七章:Mapping插件

    原文:Knockout应用开发指南 第七章:Mapping插件 Mapping插件 Knockout设计成允许你使用任何JavaScript对象作为view model.必须view model的一些 ...

  9. POJ 2942 Knights of the Round Table - from lanshui_Yang

    Description Being a knight is a very attractive career: searching for the Holy Grail, saving damsels ...

  10. 为VS2013添加SQLCE的支持

    解决 下载SQL Server Compact Toolbox by ErikEJ并安装 打开VS2013,新建一工程,在“视图>其它窗口>SQL Server Compact Toolb ...