您的位置:首页 > 数据库 > Mongodb

MongoDB的入门使用

2019-09-16 23:32 1786 查看

一: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);
MongoD
15d8
atabase 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("用户名",“新的密码”)

  

 

 

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: