设为首页 收藏本站
查看: 1021|回复: 0

[经验分享] MongoDB 查找数据基础

[复制链接]

尚未签到

发表于 2018-10-26 09:16:44 | 显示全部楼层 |阅读模式
  使用library数据库
use libraray  查看可用数据库和集合
show dbs  
show collections
  插入数据insert操作
  两种定义文档的格式:
document = ( { "Type" : "Book", "Title" : "Definitive Guide to MongoDB 2nd ed.,The", "ISBN" : "978-1-4302-5821-6", "Publisher" : "Apress", "Author": ["Hows, David","Plugge, Eelco", "Membrey, Peter", "Hawkins, Tim" ] } )  
document = ( { "Type" : "Book",
  
"Title" : "Definitive Guide to MongoDB 2nd ed.,The",
  
"ISBN" : "978-1-4302-5821-6",
  
"Publisher" : "Apress",
  
"Author": ["Hows, David","Plugge, Eelco", "Membrey, Peter", "Hawkins, Tim" ]
  
} )
  直接使用insert插入:
db.media.insert(document)  也可以不定义文档直接插入:
db.media.insert({ "Type" : "CD", "Artist" : "Nirvana", "Title" : "Nevermind" })  或:
db.media.insert( { "Type" : "CD",  
"Artist" : "Nirvana",
  
"Title" : "Nevermind",
  
"Tracklist" : [
  
{
  
"Track" : "1",
  
"Title" : "Smells Like Teen Spirit",
  
"Length" : "5:02"
  
},
  
{
  
"Track" : "2",
  
"Title" : "In Bloom",
  
"Length" : "4:15"
  
}
  
]
  
})
  查询数据find操作
  查询所有数据:
db.media.find()  查询特定的文档:
db.media.find({Artist:"Nirvana"})  查看特定的列
db.media.find({Artist:"Nirvana"},{Title:1})  只要在find中使用第二个参数{Title:1}返回标题字段信息即可。将1改为0为不显示该标题
  具体查询(有点像SQL的where条件):
db.media.find({"Tracklist.Title":"In Bloom"})  查询Tracklist下Title为“In Bloom"的数据
db.media.find({"Author":"Membrey, Peter"})  查询数组Author中含有"Membrey, Peter"的文档
  使用sort、limit、skip函数
  排序:
db.media.find().sort({Title:1})  升序,只要将Title:1改成-1就为倒序
  限制输出n个文档:
db.media.find().limit(2)  不限显示第一个文档:
db.media.find().skip(1)  三个函数结合一起使用:
  安Titile倒序,显示10个文档,跳过头一个
db.media.find().sort({Title:-1}).limit(10).skip(1)  固定顺序集合:
  创建固定顺序集合:
db.createCollection("audit",{capped:true,size:204800})  这种集合能保证插入的文档按照插入顺序排序,不会在以后更新中改变顺序。
  聚集函数(类似SQL的Group by):
  count函数:
db.media.count()  返回当前media集合有多少个文档
  指定符合条件的文档数:
db.media.find({Publisher:"Apress"}).count()  注意count会忽略skip与limit,例如:
db.media.find().skip(1).count() 等价db.media.find().count()  不想忽略skip跟limit需要在count里面添加true参数,例如:
db.media.find().skip(1).count(true)  去重复distinct函数:
  增加一个文档:
document = ( { "Type" : "Book", "Title" : "Definitive Guide to MongoDB 2nd ed.,The", "ISBN" : "978-1-4302-5821-6", "Publisher" : "Apress", "Author": ["Hows, David","Plugge, Eelco", "Membrey, Peter", "Hawkins, Tim" ] } )  
db.media.insert(document)
  
db.media.distinct("Title")
  这样相同内容的Title就会合并成一条记录
  group函数:
db.media.group({key:{Title:true},  
initial:{Total:0},
  
reduce:function(items,prev)
  
{
  
prev.Total+=200;
  
}
  
}
  
)
  条件查询:
  添加一些数据:
dvd=({ "Type" : "DVD",  
"Title" : "Matrix,The",
  
"Released":1999,
  
"Cast":["Keanu Reeves","Carrie-Anne Moss","Laurence Fishburne","Hugo Weaving","Gloria Foster","Joe Pantoliano"]})
  
dvd=({"Type":"DVD",Title:"Blade Runner",Released:1992})
  
db.media.insert(dvd)
  
dvd=({"Type":"DVD",Title:"Toy Story 3",Released:2010})
  
db.media.insert(dvd)
  大于操作:
db.media.find({Released:{$gt:2000}})  小于:
db.media.find({Released:{$lt:2000}})  gte与lte是大于等于,小于等于
  指定范围在大于等于1990到小于等于2010之间:
db.media.find({Released:{$gte:1990,$lte:2010}})  否定查询$ne:
db.media.find({Tyep:"Book",Author:{$ne:"Plugge,Eelco"}})  数组的操作:
  $in 其中一个匹配即可
db.media.find({Released:{$in:[1999,2008,2009]}})  $nin全都不匹配
db.media.find({Released:{$nin:[1999,2008,2009]}})  $all匹配所有:
db.media.find({Released:{$all:[1999,2008,2009]}})  上述语句不会返回任何数据
  $or 多条件搜索:
db.media.find({$or:[{"Title":"Toy Story 3"},{"ISBN":"978-1-4302-5821-6"}]})  添加参数限制类型:
db.media.find({ "Type" : "DVD",$or:[{"Title":"Toy Story 3"},{"ISBN":"978-1-4302-5821-6"}]})  $slice操作数组范围:
  显示前3项:
db.media.find({"Title":"Matrix,The"},{"Cast":{$slice:3}})  后三项:
db.media.find({"Title":"Matrix,The"},{"Cast":{$slice:-3}})  忽略前2项,从开始的3个数据项:
db.media.find({"Title":"Matrix,The"},{"Cast":{$slice:[2,3]}})  从倒数第5个开始输出4个数据:
db.media.find({"Title":"Matrix,The"},{"Cast":{$slice:[-5,4]}})  奇偶数操作:
  偶数的年份:
db.media.find({Released:{$mod:[2,0]}})  奇数:
db.media.find({Released:{$mod:[2,1]}})  查询数组元素数量符合特定值:
db.media.find({Tracklist:{$size:2}})  Tracklist数组只有两个元素的文档
  返回特定对象存在:
db.media.find({Author:{$exists:true}})  匹配完整的数组
  添加一个文档:
nirvana = ( { "Type" : "CD", "Artist" : "Nirvana", "Title" : "Nirvana","Tracklist" : [ { "Track" : "1", "Title" : "You Know You're Right", "Length": "3:38"}, {"Track" : "5", "Title" : "Smells Like Teen Spirit", "Length" :"5:02" } ] } )  查找Tracklist.Title为"Smells Like Teen Spirit"并且为Track 1的数据将会有多行重复
  利用$elemMatch可以匹配数组中的完整文档
db.media.find({"Tracklist":{"$elemMatch":{Title:"Smells Like Teen Spirit","Track":"1"}}})  可以使用$not否定该条件,例如:
db.media.find({"Tracklist":{$not:{"$elemMatch":{Title:"Smells Like Teen Spirit","Track":"1" }}}})


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-626590-1-1.html 上篇帖子: MongoDB(一) 下篇帖子: 【MongoDB】3.0 配置文件相关介绍
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表