MongoDB入门

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

下载

Download MongoDB Community Server | MongoDB

MongoDB的基本操作

添加数据

复制代码
db.collection.insertOne(document) // 插入单个文档  
db.collection.insertMany([document1, document2, ...]) // 插入多个文档

查询数据

复制代码
db.student.find()   //无条件查询

db.student.find({name:"周瑜"})

//查询性别是男,年龄大于20的信息
db.student.find({sex:"男",age:{$gte:20}})

修改数据

复制代码
//修改
//把20岁以上的男同学,班级改成2-6
db.student.updateMany({sex:"男",age:{$gte:20}},{$set:{class:"2-6"}})

//把曹操的年龄改成20
db.student.update({name:"曹操"},{$set:{age:20}})
  • query:用于指定查询条件。

  • update:用于指定更新操作,常用的更新操作符包括$set$inc等。

  • upsert:一个可选参数,当为true时,如果找不到符合查询条件的文档,将插入一个新文档。

删除数据

复制代码
//删除jack的年龄
db.student.update({name:"jack"},{$unset:{age:1}})

//删除
//删除2-6班所有的男同学
db.student.remove({class:"2-6",sex:"男"})
//删除所有教师记录
db.teacher.remove({})

对数组操作

复制代码
//给jack添加教务主任角色
db.teacher.update({name:"jack"},{$push:{role:"教务主任"}})
//删除jack的副校长角色
db.teacher.update({name:"jack"},{$pull:{role:"副校长"}})

查询表达式

  1. 基本查询

    • {field: value}:查询field列的值为value的文档。
  2. 比较运算符

    • $ne:不等于。例如,{field: {$ne: value}}查询field列的值不等于value的文档。

    • $gt:大于。

    • $gte:大于等于。

    • $lt:小于。

    • $lte:小于等于。

    • $in:在...之内。例如,{field: {$in: [v1, v2, ...]}}查询field列的值在数组[v1, v2, ...]中的文档。

    • $nin:不在...之内。

  3. 逻辑运算符

    • $and:所有条件都满足。

    • $or:至少一个条件满足。

    • $nor:所有条件都不满足。

  4. 元素运算符

    • $exists:检查字段是否存在。例如,{field: {$exists: 1}}查询含有field字段的文档。

    • $all:数组字段包含所有指定元素。例如,{field: {$all: [v1, v2, ...]}}查询field列是一个数组且至少包含v1, v2, ...的文档。

  5. 正则表达式

    • 使用$regex进行模式匹配。例如,{field: {$regex: /pattern/}}查询field字段匹配正则表达式pattern的文档。
  6. $where

    • 允许使用JavaScript表达式作为查询条件。例如,db.collection.find({$where: 'this.field > 10'})
相关推荐
时序数据说43 分钟前
为什么时序数据库IoTDB选择Java作为开发语言
java·大数据·开发语言·数据库·物联网·时序数据库·iotdb
戒不掉的伤怀1 小时前
【Navicat 连接MySQL时出现错误1251:客户端不支持服务器请求的身份验证协议;请考虑升级MySQL客户端】
服务器·数据库·mysql
cv高级工程师YKY1 小时前
服务器 - - QPS与TPS介绍
数据库
nbsaas-boot1 小时前
高可扩展属性建模设计:架构师的全局思考与落地方案
数据库
爱上语文1 小时前
Redis基础(5):Redis的Java客户端
java·开发语言·数据库·redis·后端
陈敬雷-充电了么-CEO兼CTO2 小时前
推荐算法系统系列>推荐数据仓库集市的ETL数据处理
大数据·数据库·数据仓库·数据挖掘·数据分析·etl·推荐算法
MeshddY2 小时前
(超详细)数据库项目初体验:使用C语言连接数据库完成短地址服务(本地运行版)
c语言·数据库·单片机
wuxinyan1232 小时前
Java面试题033:一文深入了解MySQL(5)
java·数据库·mysql·面试
萧曵 丶3 小时前
Spring @TransactionalEventListener
java·数据库·spring·事务·transactional·异步
胡斌附体3 小时前
mobaxterm终端sqlplus乱码问题解决
数据库·乱码·sqlplus·字符集设置