`

数据存储与缓存3-MongoDB-评论类系统-C++

    博客分类:
  • data
 
阅读更多
1.redis

2.memcached

3.MongoDB
3.1 MongoDB下载及安装
3.2 mongo使用-客户端
3.3 mongo使用-java
3.4 mongo使用-spring



3.MongoDB
MongoDB是适用于海量数据,大量查询的业务场景-如评论等

要使用新技术如评论系统中MongoDB替换mysql,总要适应一段时间,总觉得用老技术稳定合理点。换个角度看,如果MongoDB比mysql先出现或同时出现,现在MongoDB与mysql的市场份额又是另一番景象了

MongoDB为非关系型数据库,其结构为数据库(dbs)-集合(collections)-文档(行记录)。既然mongoDb是非关系型数据,可不可按照在spring中连接池哪样连接mongodb,其开发模式可不可以按照mvc来设计呢

3.1 MongoDB下载及安装
https://www.mongodb.com/download-center#community
下载windows相应版本,并进行安装

complete安装成功后,在win7的C:\Program Files\MongoDB\Server\3.4(具体以本机系统为准)存在bin文件夹,复制到自己定义的位置,如D:\\service\\mongodb,并在该根目录下新建logs/mongodb.log和db文件夹




cmd进入根目录(如:D:\\service\\mongodb)运行:
D:\service\mongodb\bin>mongod.exe --dbpath=d:\service\mongodb\db



最后一行表明启动成功,监听端口27017


3.2 mongo使用-客户端
进入根目录/bin:
>mongo

>use test
>db.foo.save({hello:1,world:2})
>db.foo.find()

D:\service\mongodb\bin>mongo
MongoDB shell version v3.4.4
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.4.4
Welcome to the MongoDB shell.
For interactive help, type "help".
For more comprehensive documentation, see
        http://docs.mongodb.org/
Questions? Try the support group
        http://groups.google.com/group/mongodb-user
Server has startup warnings:
2017-06-11T18:28:48.031+0800 I CONTROL  [initandlisten]
2017-06-11T18:28:48.032+0800 I CONTROL  [initandlisten] ** WARNING: Access contr
ol is not enabled for the database.
2017-06-11T18:28:48.032+0800 I CONTROL  [initandlisten] **          Read and wri
te access to data and configuration is unrestricted.
2017-06-11T18:28:48.034+0800 I CONTROL  [initandlisten]
2017-06-11T18:28:48.034+0800 I CONTROL  [initandlisten] Hotfix KB2731284 or late
r update is not installed, will zero-out data files.
2017-06-11T18:28:48.035+0800 I CONTROL  [initandlisten]
> use test
switched to db test
> db.foo.save({hello:1,world:2})
WriteResult({ "nInserted" : 1 })
> db.foo.find()
{ "_id" : ObjectId("593d1c630c25a36a368ddcfe"), "hello" : 1, "world" : 2 }
> exit
bye

D:\service\mongodb\bin>


#查询所有数据库
> show dbs

#显示当前使用的数据库
> db

#添加用户(类似数据库登录用户)
> use admin
> db.createUser({user:'sa',pwd:'sa',roles:['dbAdminAnyDatabase']})
老版本为db.addUser('sa','sa')
> db.auth("sa","sa")
具体角色:
Read:允许用户读取指定数据库
readWrite:允许用户读写指定数据库
dbAdmin:允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile
userAdmin:允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户
clusterAdmin:只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。
readAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读权限
readWriteAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的读写权限
userAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的userAdmin权限
dbAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。
root:只在admin数据库中可用。超级账号,超级权限

创建用户后,需重启mongodb服务,才能使用授权机制:
mongod.exe --dbpath=d:\service\mongodb\db -auth


#删除用户
> db.system.users.remove({user:"sa"})

#查询所有表
> show collections

#查询所有用户
> db.system.users.find()

#停止数据库
> db.shutdownServer()

#创建集合(表)
> db.createCollection("table1")

#删除集合drop
> db.foo.drop()

#修改文档update
> db.foo.update({"hello":1},{"hello":"2"})

#表数据量统计
> db.foo.count()

#帮助
> db.user.help()


3.3 mongoDB使用-java
package com.byron.mongodb.client;

import java.util.ArrayList;
import java.util.List;

import org.bson.Document;

import com.mongodb.MongoClient;
import com.mongodb.MongoCredential;
import com.mongodb.ServerAddress;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoDatabase;

public class MongoDBClient {
	public static void main(String[] args) {
		MongoClient mongoClient = null;
        try {  
            ServerAddress serverAddress = new ServerAddress("localhost",27017);  
            List<ServerAddress> addrs = new ArrayList<ServerAddress>();  
            addrs.add(serverAddress);  
              
            //MongoCredential.createScramSha1Credential()三个参数分别为 用户名 数据库名称 密码  
            // dba为数据库中创建的用户,角色为dbAdminAnyDatabase,只能在admin中使用
            // db.createUser({user:'dba',pwd:'dba',roles:['dbAdminAnyDatabase']})
            MongoCredential credential = MongoCredential.createScramSha1Credential("dba", "admin", "dba".toCharArray());  
            List<MongoCredential> credentials = new ArrayList<MongoCredential>();  
            credentials.add(credential);  
              
            //通过连接认证获取MongoDB连接  
            mongoClient = new MongoClient(addrs,credentials);  
              
            //连接到数据库  
            MongoDatabase db = mongoClient.getDatabase("sa");  
            System.out.println("Connect to database successfully");  
            
            //创建集合 参数为 “集合名称”  
            db.createCollection("t2");  
            System.out.println("Collection created successfully");  
                          
            //获取集合 参数为“集合名称”  
            MongoCollection<Document> mongoCollection = db.getCollection("t2");  
            System.out.println("Collection mycol selected successfully");  
              
            //插入文档  
            Document document = new Document("title", "hello").  
                    append("description", "world");
            List<Document> documents = new ArrayList<Document>();  
            documents.add(document);  
            mongoCollection.insertMany(documents);  
            System.out.println("Document inserted successfully");  
              
        } catch (Exception e) {  
            System.err.println( e.getClass().getName() + ": " + e.getMessage() );  
        } finally{ 
        	if (null != mongoClient) {
        		try {
        			mongoClient.close();
        		} catch (Exception e) {
        			e.printStackTrace();
        		}
        		  
        	} 
            
        }  
	}
}

对mongoDB数据库操作其实类似java通过jdbc接口对关系型数据库的操作类似,只不过接口的名字不一样


3.4 mongodb使用-spring





参考:
MongoDB 3.X 用户权限控制
http://www.cnblogs.com/shiyiwen/p/5552750.html

Win7下MongoDB的安装和部署测试
http://jingyan.baidu.com/article/f3e34a12ac10cef5eb653583.html

Mongodb安装 for windows7 64位
http://www.cnblogs.com/ajunForNet/p/4517456.html

https://www.mongodb.com
  • 大小: 24.2 KB
  • 大小: 46.2 KB
分享到:
评论

相关推荐

    logstash-input-mongodb离线包

    解压后使用,版本:logstash-input-mongodb-0.4.1 logstash离线包安装命令: Windows:logstash-plugin install file:///D:/logstash-7.5.0/logstash-input-mongodb/logstash-input-mongodb-0.4.1.zip Linux:...

    Spring-Data-MongoDB3.2

    Spring Data MongoDB项目是Spring框架的一部分,它提供了一个方便的API来操作MongoDB数据库,使得开发人员可以更高效地进行数据存储和检索。 **1. Spring Data MongoDB简介** Spring Data MongoDB提供了与MongoDB...

    logstash-input-mongodb-0.4.1[logstash-6.5.4]

    《Logstash-input-mongodb插件详解与应用》 在大数据处理和日志分析领域,Logstash以其强大的数据收集、处理和转发能力而被广泛应用。在本文中,我们将深入探讨一个关键组件——logstash-input-mongodb插件,以及...

    前端开源库-node-red-contrib-mongodb2

    总结来说,`node-red-contrib-mongodb2` 是 Node-RED 平台上用于与 MongoDB 交互的重要工具,它极大地简化了数据处理流程,并提供了丰富的 MongoDB 功能,适用于各种需要数据库集成的场景。通过熟练掌握和运用这个库...

    Studio3T+data-man-mongodb-ent-2019.3.0.jar

    Studio3T mac 加 data-man-mongodb-ent-2019.3.0.jar

    logstash-input-mongodb-master.zip

    (3) 修改logstash目录下的 Gemfile 文件 添加配置 gem "logstash-input-mongodb", :path =&gt; "./logstash-input-mongodb-master" (4) logstash bin目录下执行 logstash-plugin install --no-verify 命令安装 ...

    percona-backup-mongodb_1.6.1-1-最新版.zip

    percona-backup-mongodb-1.6.1-1.el7.x86_64.rpm、 percona-backup-mongodb-1.6.1-1.el8.x86_64.rpm、 percona-backup-mongodb-1.6.1-x86_64.tar.gz、 percona-backup-mongodb_1.6.1-1.bionic_amd64.deb、 percona-...

    spring-data-mongodb增强工具包,简化 CRUD 操作,提供类mybatis plus的数据库操作体验

    spring-data-mongodb增强工具包,简化 CRUD 操作,提供类mybatis plus的数据库操作。传统关系型数据库及围绕它们构建的orm在项目开发中有很多难用的痛点,而mongodb这种文档性数据库的出现,完美的解决了sql数据库在...

    Spring集成MongoDB官方指定jar包:spring-data-mongodb-1.4.1.RELEASE.jar

    Spring集成MongoDB官方指定jar包:spring-data-mongodb-1.4.1.RELEASE.jar

    spring-data-mongodb-1.8.0.RELEASE(含源码)

    Spring Data MongoDB 提供了高级抽象,使得开发人员能够以一种声明式的方式处理 MongoDB 数据存储,减少了对低级 API 的直接调用,从而提高了开发效率。 1. **核心概念** - **MongoTemplate**:这是 Spring Data ...

    spring-data-mongodb.jar

    spring支持mongodb的jar包

    spring-data-mongodb-reference-docs-1.9.4

    spring-data-mongodb-referrence-docs-1.9.4

    spring-data-mongodb-1.8.0.RELEASE.jar

    spring-data-mongodb-1.8.0.RELEASE.jar

    Spring-data-mongodb 1.0 API 英文版

    Spring-data-mongodb的文档太少了,基本都是网页版,我把网页做成了chm方便开发人员查看,文档是英文原版,是从官网抓下来的

    spring-data-mongodb-1.7.2.jar

    spring整合mongodb3.0的jar包,据说已经解决了最新用户验证的问题

    spring-data-mongodb-reference 1.5.4

    Spring Data MongoDB 是 Spring Data 项目的一部分,旨在简化 MongoDB 数据访问,并提供一个一致的编程模型,该模型适用于 Spring Framework 中的所有数据存储技术。Spring Data MongoDB 1.5.4 版本为开发者提供了更...

    spring-data-mongodb-parent-reference

    Spring Data MongoDB 是一个为 MongoDB 文档数据库提供数据访问支持的框架,它属于 Spring Data 项目的一部分,目的是简化基于 Java 应用的数据访问层的编程工作。通过使用 Spring Data MongoDB,开发人员可以很容易...

    PyPI 官网下载 | krules-subjects-storage-mongodb-0.8.5.tar.gz

    在`krules-subjects-storage-mongodb`中,MongoDB被用作后端存储,可以提供高效的数据查询和操作能力。 **版本号0.8.5** 版本号0.8.5表示这是该模块的第8次重大更新后的第五个小版本。通常,版本号的增加意味着...

    connect-mongodb-session, 轻量级MongoDB支持用于连接和表达的会话存储.zip

    connect-mongodb-session, 轻量级MongoDB支持用于连接和表达的会话存储 connect-mongodb-session:用于连接的-backed会话存储和 Express 。 这意味着它是一个很好的维护和完全功能的模块,如连接 mongo 。 ...

    spring-data-mongodb1.2.0

    Spring Data MongoDB是一个强大的Java库,它为开发人员提供了一种简单而有效的方式来集成Spring应用程序与...无论你是构建简单的单体应用还是复杂的分布式系统,这个库都能帮助你快速、高效地完成数据存储和检索任务。

Global site tag (gtag.js) - Google Analytics