前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MongoDB入门实操《中篇》

MongoDB入门实操《中篇》

作者头像
Wu_Candy
发布2022-07-04 16:57:10
2190
发布2022-07-04 16:57:10
举报
文章被收录于专栏:无量测试之道

1

常规命令使用


首先我们来了解几个概念,虽然MongoDB入门实操《上篇》这篇文章已经提到过,这里再次加深印象: 集合:Mongo 中的集合就是mysql 的表的表现形式 文档:文档的数据结构和JSON 基本一样,它就是集合(表)中的一条记录,相当于mysql 的行row 字段:Mongo 中的field 相当于mysql 中的column 索引:Mongo 中的index 与mysql 的index 一样 主键:Mongo 中的primary key 与mysql 的一样,其中Mongo 中将_id 自动设置为主键

2

向集合中插入数据


有两种方式,注意一下插入的数据格式 insert and save,如下:

代码语言:javascript
复制
> db.test.insert({"name":"tony","age":23,"job":"tester"})
WriteResult({ "nInserted" : 1 })
> db.test.save({"name":"tom","age":29,"job":"developer"})
WriteResult({ "nInserted" : 1 })
> db.test.find()
{ "_id" : ObjectId("5eecc55ec2e3725b5715931b"), "name" : "tony", "age" : 23, "job" : "tester" }
{ "_id" : ObjectId("5eecc5a3c2e3725b5715931c"), "name" : "tom", "age" : 29, "job" : "developer" }

3

删除集合中的数据

代码语言:javascript
复制
> db.test.remove({"name":"jim"})
WriteResult({ "nRemoved" : 1 })

4

修改集合中的数据

代码语言:javascript
复制
> db.test.update({"name":"tony"},{$set:{"age":30}}) #只更新第一条记录,name=tony 的age 修改为30
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.test.update({"name":"tony"},{$set:{"age":30}},false,true ); #满足条件的全部更新

备注:上一条命令中false and true 解释:

  • upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
  • multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新

5

查询集合中的数据

代码语言:javascript
复制
> db.test.find({"age":{$gt:29}}) #查询age 大于29的文档
{ "_id" : ObjectId("5eecc55ec2e3725b5715931b"), "name" : "tony", "age" : 33, "job" : "tester" }
备注:
MongoDB中条件操作符有:
* (>) 大于 - $gt
* (<) 小于 - $lt
* (>=) 大于等于 - $gte
* (<= ) 小于等于 - $lte (大家可以多去练习)


> db.test.find({"name":{$in:["tony","tom"]}}) #类似mysql 里面的in 操作查询
{ "_id" : ObjectId("5eecc55ec2e3725b5715931b"), "name" : "tony", "age" : 33, "job" : "tester" }
{ "_id" : ObjectId("5eecc5a3c2e3725b5715931c"), "name" : "tom", "age" : 29, "job" : "developer" }


> db.test.find({"name":"tom","age":29}) #这种就是mysql 里面的 name='tom' and age=29 
{ "_id" : ObjectId("5eecc5a3c2e3725b5715931c"), "name" : "tom", "age" : 29, "job" : "developer" }


> db.test.find({$or:[{"name":"tom"},{"age":33}]}) #这种就是mysql 里面的 name='tom' or age=33
{ "_id" : ObjectId("5eecc55ec2e3725b5715931b"), "name" : "tony", "age" : 33, "job" : "tester" }
{ "_id" : ObjectId("5eecc5a3c2e3725b5715931c"), "name" : "tom", "age" : 29, "job" : "developer" }


$type操作符是基于集合中对应的数据类型,并返回结果。
> db.test.find() #这是现有的数据
{ "_id" : ObjectId("5eecc55ec2e3725b5715931b"), "name" : "tony", "age" : 33, "job" : "tester" }
{ "_id" : ObjectId("5eecc5a3c2e3725b5715931c"), "name" : "tom", "age" : 29, "job" : "developer" }
{ "_id" : ObjectId("5eeccc7b613abf5d90d640a2"), "name" : "kim", "age" : 39, "job" : "developer" }
{ "_id" : ObjectId("5eeccd88613abf5d90d640a3"), "name" : "jim", "age" : "39", "job" : "developer" }


> db.test.find({"age":{$type:"string"}}) #这里要求只查询出age 字段值是string 类型的数据
{ "_id" : ObjectId("5eeccd88613abf5d90d640a3"), "name" : "jim", "age" : "39", "job" : "developer" }
> db.test.find({"age":{$type:2}}) #2 和 string 是同一种表示,两种不同方式
{ "_id" : ObjectId("5eeccd88613abf5d90d640a3"), "name" : "jim", "age" : "39", "job" : "developer" }


> db.test.find({"age":{$type:1}}) #1 表示是数字类型,也可以用Double 来代替
{ "_id" : ObjectId("5eecc55ec2e3725b5715931b"), "name" : "tony", "age" : 33, "job" : "tester" }
{ "_id" : ObjectId("5eecc5a3c2e3725b5715931c"), "name" : "tom", "age" : 29, "job" : "developer" }
{ "_id" : ObjectId("5eeccc7b613abf5d90d640a2"), "name" : "kim", "age" : 39, "job" : "developer" }

limit() 方法的使用,这也相当于是mysql 里面的limit 用法,limit()方法接受一个数字参数,该参数指定从MongoDB中读取的记录条数。
> db.test.find({"age":{$type:1}}).limit(1)
{ "_id" : ObjectId("5eecc55ec2e3725b5715931b"), "name" : "tony", "age" : 33, "job" : "tester" }

skip()方法可以用来跳过指定数量的数据,skip方法同样接受一个数字参数作为跳过的记录条数。
> db.test.find({"age":{$type:1}}).skip(1) #跳过第一条记录数据,默认情况下skip() 参数为0
{ "_id" : ObjectId("5eecc5a3c2e3725b5715931c"), "name" : "tom", "age" : 29, "job" : "developer" }
{ "_id" : ObjectId("5eeccc7b613abf5d90d640a2"), "name" : "kim", "age" : 39, "job" : "developer" }

limit() 与 skip() 方法联合使用:
> db.test.find({"age":{$gt:29}}).skip(1).limit(3)
{ "_id" : ObjectId("5eeccc7b613abf5d90d640a2"), "name" : "kim", "age" : 39, "job" : "developer" }
{ "_id" : ObjectId("5ef74025613abf5d90d640a4"), "name" : "jeffy", "age" : 40, "job" : "developer" }
{ "_id" : ObjectId("5ef74035613abf5d90d640a5"), "name" : "jeee", "age" : 35, "job" : "developer" }
上面这条命令的操作相当于mysql 的 select * from test where age>29 limit 1,3;

总结:今天主要分享了MongoDB 中常见的操作增、删、改和查操作,这将有利于我们快速的进入到MongoDB 的世界中去。

友情提示:“无量测试之道”原创著作,欢迎关注交流,禁止第三方不显示文章来源时转载。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-06-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 无量测试之道 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档