zoukankan      html  css  js  c++  java
  • 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")
    
  • 相关阅读:
    linux C 代码查看推荐 anjuta
    Fixes error: "Couldnt load module pthres" and similar.
    mfloatabi=name
    ubuntu 阅读chm 文件
    android 文件系统挂报错 switch_root: bad init /sbin/init: No such file or directory
    writel __raw_writel mb()/rmb()/wmb()
    企业创新里的阴和阳
    关于verilog testbench
    Git使用初步
    Latchup初认识
  • 原文地址:https://www.cnblogs.com/artwalker/p/13365467.html
Copyright © 2011-2022 走看看