Loading

Day01_mongoDB入门

学于黑马和传智播客联合做的教学项目 感谢
黑马官网:http://www.itheima.com
传智播客官网:http://www.itcast.cn
微信搜索"艺术行者",关注并回复关键词"学成在线"获取视频和教程资料!
b站在线视频:https://www.bilibili.com/video/BV1GA411v7Vo/

mongodb入门

1 mongodb安装

MongoDB 提供了 OSX 平台上 64 位的安装包,你可以在官网下载安装包。
下载地址:https://www.mongodb.com/download-center#community

接下来我们使用 curl 命令来下载安装:

# 进入 /usr/local
cd /usr/local

# 下载
sudo curl -O https://fastdl.mongodb.org/osx/mongodb-osx-ssl-x86_64-4.0.9.tgz

# 解压
进入该目录手动解压此压缩包

# 重命名为 mongodb 目录
手动重新命名为mongodb

安装完成后,我们可以把 MongoDB 的二进制命令文件目录(安装目录/bin)添加到 PATH 路径中:

vim ~/.bash_profile

# 将mongodb的bin目录设置到PATH变量中

2 运行 MongoDB

mongod --dbpath '/Development/MongoDB/data/db' #更改指定运行路径

因为MacOS的原因,需要指定一个/data/db目录

再打开一个终端进入执行以下命令进入命令行客户端:

mongo

客户端工具使用的DataGrip

3 mongodb入门

3.1 基础概念

在mongodb中是通过数据库、集合、文档的方式来管理数据,下边是mongodb与关系数据库的一些概念对比:

SQL术语/概念 MongoDB术语/概念 解释/说明
database database 数据库
table collection 数据库表/集合
row document 数据记录行/文档
column field 数据字段/域
index index 索引
table joins 表连接(MongoDB不支持)
primary key primary key 主键,MongoDB自动在每个集合中添加_id的主键

1、一个mongodb实例可以创建多个数据库

2、一个数据库可以创建多个集合

3、一个集合可以包括多个文档。

3.2 连接mongodb

mongodb的使用命令行客户端连接mongodb数据库(服务端)。

1、使用mongodb自带的javascript shell(mongo)连接

mongo

2、使用DataGrip连接

4、使用java程序连接

添加依赖:

<dependency> 
  <groupId>org.mongodb</groupId> 
  <artifactId>mongo‐java‐driver</artifactId> 
  <version>3.4.3</version> 
</dependency>

测试程序:

@Test
public void testConnection(){
        //创建mongodb 客户端
        MongoClient mongoClient=new MongoClient("localhost",27017);
        //或者采用连接字符串
        //MongoClientURI connectionString = new MongoClientURI("mongodb://root:root@localhost:27017");
        //MongoClient mongoClient = new MongoClient(connectionString);
        //连接数据库
        MongoDatabase database=mongoClient.getDatabase("test");
        // 连接collection
        MongoCollection<Document> collection=database.getCollection("student");
        //查询第一个文档
        Document myDoc=collection.find().first();
        //得到文件内容 json串 
        String json=myDoc.toJson();
        System.out.println(json);
}

3.3 数据库

1、查询数据库

show dbs 查询全部数据库
db 显示当前数据库

2、创建数据库

use DATABASE_NAME

例子:

use test02

有test02数据库则切换到此数据库,没有则创建。

注意:

新创建的数据库不显示,需要至少包括一个集合。

3、删除数据库(慎用!!!)

db.dropDatabase()

例子:

删除test02数据库 
先切换数据库:use test02
再执行删除:db.dropDatabase()

3.4 集合

集合相当于关系数据库中的表,一个数据库可以创建多个集合,一个集合是将相同类型的文档管理起来。

1、创建集合

db.createCollection(name, options)
name: 新创建的集合名称
options: 创建参数

2、删除集合

db.collectionName.drop()
例子:
db.student.drop() 删除student集合

3.5 文档

3.5.1 插入文档

mongodb中文档的格式是json格式,下边就是一个文档,包括两个key:_id主键和name

{
		"_id" : ObjectId("5b2cc4bfa6a44812707739b5"), 
  	"name" : "黑马程序员"
}

插入命令:

db.COLLECTION_NAME.insert(document)

每个文档默认以_id作为主键,主键默认类型为ObjectId(对象类型),mongodb会自动生成主键值。

例子:

db.student.insert({"name":"黑马程序员","age":10})

注意:同一个集合中的文档的key可以不相同!但是建议设置为相同的。

3.5.2 更新文档

命令格式:

db.collectionName.update(
	{query},
	{update},
	{options}
)
query:查询条件,相当于sql语句的where
update:更新文档内容
options:选项

1、替换文档

将符合条件 "name":"北京黑马程序"的第一个文档替换为{"name":"北京黑马程序员","age":10}。

db.student.update({"name":"黑马程序员"},{"name":"北京黑马程序员","age":10})

2、$set修改器

使用$set修改器指定要更新的key,key不存在则创建,存在则更新。

将符合条件 "name":"北京黑马程序"的所有文档更新name和age的值。

db.student.update({"name":"黑马程序员"},{$set:{"name":"北京黑马程序员","age":10}},{multi:true})
# multi:false表示更新第一个匹配的文档,true表示更新所有匹配的文档。

3.5.3 删除文档

命令格式:

db.student.remove({query})
# query:删除条件,相当于sql语句中的where

1、删除所有文档

db.student.remove({})

2、删除符合条件的文档

db.student.remove({"name":"黑马程序员"})

3.5.4 查询文档

命令格式:

db.collection.find(query, projection)
# query:查询条件,可不填
# projection:投影查询key,可不填

1、 查询全部

db.student.find()

2、查询符合条件的记录

查询name等为"黑马程序员"的文档。

db.student.find({"name":"黑马程序员"})

3、投影查询

只显示name和age两个key,_id主键不显示。

db.student.find({"name":"黑马程序员"},{name:1,age:1,_id:0})

3.6 用户

6.6.1 创建用户

语法格式:

db.createUser(
	{
		user:"username",
		pwd:"password",
		customData:{any information},
		roles:[{role:"role", db:"database"} | "role",
		...
		]
	}
)

例子:

创建root用户,角色为root

use admin
db.createUser(
	{
		user:"root",
		pwd:"root",
		roles:[{role:"root",db:"admin"}]
	}
)

内置角色如下:

1. 数据库用户角色:read、readWrite;
2. 数据库管理角色:dbAdmin、dbOwner、userAdmin;
3. 集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;
4. 备份恢复角色:backup、restore;
5. 所有数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、 dbAdminAnyDatabase
6. 超级用户角色:root

3.6.2 查询用户

查询当前库下的所有用户:

show users

3.6.3 删除用户

语法格式:

db.dropUser("用户名")

例子:

删除root1用户

db.dropUser("root1")

3.6.4 修改用户

db.updateUser(
	"username",
	{
		customData : { <any information> },
		roles : [
				{ role: "<role>", db: "<database>" } | "<role>",
				...
				],
		pwd: "<cleartext password>"
	},
	writeConcern: { <write concern> }
)

例子:

修改root用户的角色为readWriteAnyDatabase

use admin
db.updateUser("root",{roles:[{role:"readWriteAnyDatabase",db:"admin"}]})

3.6.5 修改密码

语法格式:

db.changeUserPassword("username","newPasswd")

例子:

修改root用户的密码为123

use admin
db.changeUserPassword("root","123")
posted @ 2020-07-23 11:52  Artwalker  阅读(137)  评论(0编辑  收藏  举报
Live2D