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

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

猜你喜欢

转载自newjava-sina-cn.iteye.com/blog/2378954