返回顶部
首页 > 资讯 > 数据库 >MongoDB 查找数据基础
  • 453
分享到

MongoDB 查找数据基础

2024-04-02 19:04:59 453人浏览 八月长安
摘要

使用library数据库use libraray查看可用数据库和集合show dbs  show collections插入数据insert操作两种定义文档的格式:d

使用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" }}}})


您可能感兴趣的文档:

--结束END--

本文标题: MongoDB 查找数据基础

本文链接: https://lsjlt.com/news/36028.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MongoDB 查找数据基础
    使用library数据库use libraray查看可用数据库和集合show dbs  show collections插入数据insert操作两种定义文档的格式:d...
    99+
    2024-04-02
  • MongoDB数据库—基础语法
    一、MongoDB 数据库的特点及安装 MongoDB 数据库的特点 面向文档,模式自由 json数据模式(bson)(可以初略理解为字典) 多级引索 高可用复制集 水平扩展 跨平台、多种语言接口 弱事...
    99+
    2024-04-02
  • MongoDB基础之查询文档
    目录一、查询文档实例二、条件操作符MongoDB 与 RDBMS Where 语句比较举例:使用 (<) 和 (>) 查询 - $lt 和 $gt三、AND 条...
    99+
    2024-04-02
  • MongoDB数据库基础知识整理
    一、NoSQL 了解MongoDB之前先了解一下NoSQL,NoSQL是Not Only SQL的缩写。由提供缺乏SQL关系数据库的严格限制模型的存储和检索技术组成。主要是简化设计、水平扩展以及对数据的可用性进行更精细的...
    99+
    2022-07-07
    MongoDB数据库 基础知识
  • 【MongoDB】01、MongoDB基础
    一、MongoDB概述1、MogoDB简介什么是MongoDB MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。在高负载的情况下,添加更多的节点,可以保证服务器性能...
    99+
    2024-04-02
  • MongoDB基础
    一、概述1.1 MongoDB概念MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。在高负载的情况下,添加更多的节点,可以保证服务器性能。MongoDB 旨在为WEB应用提供可...
    99+
    2024-04-02
  • Python字典查找数据的5个基础操作方法
    目录前言一、key值查找二、函数查找2.1 get()2.2 keys()2.3 values()2.4 items()附:字典的常用方法总结前言 上一篇文章写了关于字典操作方法的增...
    99+
    2024-04-02
  • 总结MongoDB数据库的基础操作
    这篇文章主要讲解了总结MongoDB数据库的基础操作,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。本文实例讲述了MongoDB数据库基础操作。分享给大家供大家参考,具体如下:1...
    99+
    2024-04-02
  • 【MongoDB学习笔记14】MongoDB的查询:find基础
    MongoDB中使用find来进行查询,返回一个集合中的文档的子集;返回文档集合blog中的所有文档:> db.post.find()    { "_...
    99+
    2024-04-02
  • mysql 基础篇-数据查询(1)
    一、查询数据的概念:查询数据、筛选数据、确定数据的以什么样的格式输出。二、数据查询的基本语句   1、基本语句格式 :select 字段列表  FROM 表或者视图 ...
    99+
    2024-04-02
  • 详解MongoDB数据库基础操作及实例
    详解数据库基础操作及实例           废话不多说,直接上代码,注释写的比较清楚,大家参考下,  示...
    99+
    2024-04-02
  • MongoDB数据库基础操作的示例分析
    这篇文章将为大家详细讲解有关MongoDB数据库基础操作的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。为了保存网站的用户数据和业务数据,通常需要一个数据库。Mo...
    99+
    2024-04-02
  • MongoDB基础入门
    简介 • MongoDB是为快速开发互联网Web应用而设计的数据库系统。 • MongoDB的设计目标是极简、灵活、作为Web应用栈的一部分。 • MongoDB的数据模型是面向文档的,所谓文档是一种类似于JSON的结构,Mong...
    99+
    2021-02-07
    MongoDB基础入门
  • MongoDB基础操作
    MongoDB增删改查操作 MongoDB数据库服务启动和关闭 net start mongodb net stop mongodb 数据库连接 先使用npm install mongoose安装mongoose依赖,之后使用mongoo...
    99+
    2017-01-10
    MongoDB基础操作 数据库入门 数据库基础教程 数据库 mysql
  • MongoDB基础知识
    NoSQL是什么?   非关系型数据库,有时也称作Not Only SQL的缩写,是对不同于传统的关系型数据库的数据库管理系统的统称 NoSQL的优势  &...
    99+
    2024-04-02
  • MongoDB基础安装
    MongoDB基础安装 MongoDB概述 (1)MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。 (2)MongoDB是一个介于关系数...
    99+
    2024-04-02
  • MongoDb基础命令
    一些基础忘记随时查看。。#整备恢复mongodump --port 20001 --authenticationDatabase=admin -u *  -d lvlv -c lvlv -o /h...
    99+
    2024-04-02
  • MySQL基础:基础查询
    DQL语言:数据查询语言 3.1 基础查询 语法 select 查询列表 from 表名; 特点 查询列表可以是字段、常量、表达式、函数,也可以是多个 查询结果是一个虚拟表 示例 1、查询单个字段 selec&#...
    99+
    2016-06-13
    MySQL基础:基础查询
  • MongoDB基础知识(一)
     互联网行业的发展非常的迅速,数据存储以及架构优化方面也有很多不同的解决方案,例如关系型数据库、非关系型数据库、数据仓库技术等。更多数据库类产品的出现,为我们很好的解决了数据存储的问题,例如Red...
    99+
    2024-04-02
  • Mongodb基础实践(二)
      在前面的文章里面主要介绍了MongoDB的文档,集合,数据库等操作和对文档的增、删、改相关知识,接下来会总结一点有关查询的相关知识。  在MySQL中,我们知道数据查询是优化的主要内...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作