一只菜鸟攻城狮啊

一只菜鸟攻城狮啊

一:MonoDB的简单介绍

MongoDB是一个介于关系型数据库与非关系型数据库中间的数据库,是使用C++进行编写的,他的优点是在支持的查询格式特别的强大,可以进行存储比较复杂的数据类型,支持建立索引

二:下载

官方地址:https://www.mongodb.com/
本教程下载 3.4版本:http://downloads.mongodb.org/win32/mongodb-win32-x86_64-2008plus-ssl-v3.4-latest-signed.msi
 
三:安装与启动服务
1,对MongoDB进行安装之后,在bin的同级目录下创建 数据库路径(data目录),日志路径(logs目录)和 日志文件(mongo.log文件)
2,创建并编辑配置文件:mongo.conf
#数据库路径
dbpath=d:\MongoDB\Server\3.4\data
#日志输出文件路径
logpath=d:\MongoDB\Server\3.4\logs\mongo.log
#错误日志采用追加模式
logappend=true
#启用日志文件,默认启用 /ˈdʒɜːnl/ 日志,日记
journal=true
#这个选项可以过滤掉一些无用的日志信息,若需要调试使用请设置为false
quiet=true
#端口号 默认为27017
port=27017

3,进入bin目录下,使用管理员进入命令行窗口,执行下面的命令进行安装

mongod.exe --config " xxxx/mongo.conf(路径) " --install

4,执行对应的命令

 net start MongoDB #启动MongoDB
 net stop MongoDB  #关闭MongoDB
 “...../mongod.exe” --remove #移除MongoDB

5,验证是否启动成功

访问:http://localhost:27017 查询MongoDB的页面

四:对于客户端的安装:

目前对于MongoDB 的客户端有很多可以自行下载,我推荐的是nosqlbooster,下载地址:https://nosqlbooster.com/downloads

五:java对MongoDB的简单使用

1,服务的连接格式

mongodb://[username:password@]host1[:port1][,host2[:port2],...[,hostN[:portN]]][/[database][?options]]

对应的名词解释: 

  mongodb:// 固定前缀
  username:账号,可不填
  password:密码,可不填
  host:主机名或ip地址,只有host主机名为必填项。
  port:端口,可不填,默认27017
  /database:连接某一个数据库
  ?options:连接参数,key/value对
 
示例:
1,mongodb://localhost 连接本地数据库27017端口
2,mongodb://root:itcast@localhost 使用用户名root密码为itcast连接本地数据库27017端口
3,mongodb://localhost,localhost:27018,localhost:27019,连接三台主从服务器,端口为27017、27018、27019
 
2,添加依赖
 <dependency>
     <groupId>org.mongodb</groupId>
    <artifactId>mongo-java-driver</artifactId>
    <version>3.4.3</version>
</dependency>

3,代码测试连接

   //测试连接
    @Test
    public void testConnect(){
        //创建客户端
        MongoClient mongoClient = new MongoClient("localhost", 27017);
        //采用连接字符串简历连接
        // MongoClientURI connecting = new  MongoClientURI("mongodb://localhost:27017/test"); //记得数据库的名字
        //MongoClient client = new MongoClient(connecting);
        MongoDatabase database = mongoClient.getDatabase("test");//获取数据库
        MongoCollection<Document> collection = database.getCollection("student"); //获取对应的表
        Document document = collection.find().first(); //获取对应的行
        String json = document.toJson();
        System.out.println(json);
    }

  注意:在使用URI进行连接的时候,加上数据库的名字,如果出现了如下的错误,【MongoCommandException: Command failed with error 18: 'Authentication      failed.】,此时请检查连接的地址以及用户是否是该数据库所属的用户,在MongoDB中,一个用户对应一个库,在连接时应写对应的

六:MongoDB涉及命令

#数据库以及集合相关
1,show dbs 查询全部数据库
2,use dbbase_name 切换或者创建数据库
3,db.dropDatabase() 删除数据库,要先切换到对应的数据库下
4,db.createCollection(name,options),
5,db.collectionName.drop()  删除集合
6,db.collectionName.insert({"key": "value"}) 对集合添加数据
7,db.collectionName.update( {更新条件},{更新的内容},选项 )
8,db.collectionName.remove({删除条件})根据条件进行删除文档
9,db.collectionName.remove()  删除所有的文档
10,db.collectionName.find({查询条件}),没有条件就是查询所有的文档
11,db.collectionName.find({查询条件},{要显示的字段,需要显示的是1,不需要显示的是0,不用加双引号}),投影查询

#用户相关
1,先切换到对应的数据库下:use databaseName
2,sb.createUser({
        user: "username",
        pwd:"密码",
        roles:[
        { role:"角色",db:"数据库名字"   }
    ]
})
show users: 查询用户
db.dropUser(“ 用户名 ”)  删除用户
db.updateUser("用户名",{roles:[{role:"角色",db:“数据库角色”}]}) 修改用户信息
db.changeUserPassword("用户名",“新的密码”)

  

MongoDB的入门使用-LMLPHP

09-17 07:39