• NodeJS学习笔记之MongoDB模块


    其中还有,nodejs远程连接mysql数据库

    一,开篇分析

    这篇属于扩展知识篇,因为在下面的文章中会用到数据库操作,所以今天就来说说它(Mongodb模块)。

    (1),简介

     MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。

     MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSql数据库中比较热门的一种。

     MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。

    传统的关系数据库一般由数据库(database)、表(table)、记录(record)三个层次概念组成,MongoDB是由数据库(database)、集合(collection)、文档对象(document)三个层次组成。

    MongoDB对于关系型数据库里的表,但是集合中没有列、行和关系概念,这体现了模式自由的特点。

    (2),特点

     它的特点是高性能、易部署、易使用,存储数据非常方便。主要功能特性有:

     1)面向集合存储,易存储对象类型的数据。
     2)模式自由。
     3)支持动态查询。
     4)支持完全索引,包含内部对象。
     5)支持查询。
     6)支持复制和故障恢复。
     7)使用高效的二进制数据存储,包括大型对象(如视频等)。
     8)自动处理碎片,以支持云计算层次的扩展性。
     9)支持RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
     10)文件存储格式为BSON(一种JSON的扩展)。
     11)可通过网络访问。

    一、根据之前的文章启动mongo数据库时,(一定要先启动mongo数据库)

    在shell 命令窗口键入如下命令:" use bb" (use 命令用来切换当前数据库,如果该数据库不存在,则会先新建一个)。

    在shell 命令窗口键入如下命令:“ db.users.insert({"name":"bigbear","password":"12345678"})”,(这条命令是向users 集合中插入一条数据,如果集合users不存在,则会先新建一个,然后再插入数据,参数以JSON格式传入)。在shell 命令窗口键入如下命令:“db.users.find()” (显示users集合下的所有数据文档),如下图:

    注意图中的“_id”,系统给每条记录自动分配了一个惟一主键 _id 。

    好了!基本的功能够用了,后面如果需要额外的操作逐步补充,由于篇幅有限主要说的是NodeJS操作Mongodb,所以暂时告一段落。

    二、然后进入用nodejs操作该数据库的部分

     var mongodb = require("mongodb") ;
     var server = new mongodb.Server("localhost",27017,{
         auto_reconnect : true
     }) ;
     var conn = new mongodb.Db("wly",server,{
         safe : true
     }) ;
     conn.open(function(error,db){
         if(error) throw error ;
         db.collection("users",{
             safe : true
         },function(err,collection){
             if(err) throw err ;
             collection.find().toArray(function(e,docs){
                 if(e) throw e ;
                 console.log(docs) ;
             }) ; 
         }) ;
     }) ;

    结果如下图:

    本文操作的app.js下载链接在此

  • 相关阅读:
    redis 配置文件说明
    Python 详解命令行解析
    Python 的字符编码
    pt-online-schema-change utf8mb4 错误解决方法【转】
    [MySQL 5.6] Innodb新特性之export/import 表文件
    查找数据库大小和表大小
    MySQL 增删列
    使用MySQL Shell创建MGR
    Qingcloud_MySQL Plus(Xenon) 高可用搭建实验
    MySQL事务提交流程
  • 原文地址:https://www.cnblogs.com/wanliyuan/p/5530924.html
Copyright © 2020-2023  润新知