MongoDB 学习总结

MongoDB是什么?

MongoDB 是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。

MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。-------w3cschool

一、数据库操作

use mydb

在创建了数据库后需要先插入集合才能被查询到

插入数据:
db.mydb.insert({"zlz":"学习"})

查询数据库

show dbs

删除数据

1.先切换到需要删除的数据库
use mydb
2.执行删除命令
db.dropDatabase()

二、集合操作

2.1 创建集合

参数说明:

name要创建的集合名称
options可选参数, 指定有关内存大小及索引的选项
db.createCollection(name, options)

2.2 查看已存在集合

show collections

2.3 删除集合

db.collection.drop()

删除集合:db.集合名称.drop()

三、文档操作

文档操作统一使用assemble集合

3.1 插入文档

MongoDB 使用 insert() 或 save() 方法向集合中插入文档

db.COLLECTION_NAME.insert(document)
或
db.COLLECTION_NAME.save(document)
document的格式类似于Json数据格式:
{
	a:"a",
	b:2
}

往assemble集合插入一个文档:

db.assemble.insert({a:"a",b:"2"})
或
db.assemble.insert({a:{b:"d"}})
或
db.assemble.insert({a:[{b:"d"},{e:"e"}]})

插入多个文档

db.assemble.insert(db.assemble([{a:"d"},{e:"dd"}]))

定义变量方式插入文档:

定义变量:
document=([{title:"标题"},{content:"内容"}])
插入:
db.assemble.insert(document)

注:一个{}代表一个文档

3.2 查看集合里的文档

db.assemble.find().pretty()
或
db.assemble.find()

3.3 更新文档

参数说明
updateupdate的对象和一些更新的操作符(如 , , ,inc…)等,也可以理解为sql update查询内set后面的
upsert可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
writeConcern可选,抛出异常的级别。
db.collection.update(
   <query>,
   <update>,
   {
     upsert: <boolean>,
     multi: <boolean>,
     writeConcern: <document>
   }
)

插入测试数据

db.assemble.inster({title:'天气',content:'爆炸热'})

更新数据

db.assemble.update({title:"标题"},{$set:{title:"广东天气"}})

以上语句只会修改第一条发现的文档,要修改多条相同的文档,则需要设置 multi 参数为 true。

3.4 删除文档

参数说明
query(可选)删除的文档的条件
justOne(可选)如果设为 true 或 1,则只删除一个文档,如果不设置该参数,或使用默认值 false,则删除所有匹配条件的文档。
db.collection.remove(
   <query>,
   <justOne>
)

例:

删除第一条数据:
db.COLLECTION_NAME.remove(DELETION_CRITERIA,1)
删除所有:
db.col.remove({})  
db.col.find() 
db.assemble.remove({'title':'标题'})
删除 status 等于 A 的全部文档:
db.assemble.deleteMany({ status : "A" })
删除 status 等于 D 的第一个文档:
db.assemble.deleteOne( { status: "D" } )

3.5 查询文档

db.assemble.find()
db.assemble.find().pretty()

MongoDB 的 find() 方法可以传入多个键(key),每个键(key)以逗号隔开,即常规 SQL 的 AND 条件

db.assemble.find({a:"a"})

以下实例演示了 AND 和 OR 联合使用,类似常规 SQL 语句为: ‘where price>10 AND (commodity = ‘荔枝’ OR day = ‘2021/6/1’)’

db.assemble.find({"price": {$gt:10}, $or: [{"commodity  ": "荔枝"},{"day ": "2021/6/1"}]}).pretty()

注:
(>) 大于 - $gt
(<) 小于 - $lt
(>=) 大于等于 - $gte
(<= ) 小于等于 - $lte

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值