当前位置: 首页 > news >正文

门户网站开发要求徐州集团网站建设报价

门户网站开发要求,徐州集团网站建设报价,网站通栏怎么做,个性化定制网站有哪些在投射中&#xff0c;使用$操作符和$elemMatch返回数组中第一个符合查询条件的元素。而在投射中使用$slice, 能够返回指定数量的数组元素。 定义 投射中使用$slice命令&#xff0c;指定查询结果中返回数组元素的数量。 语法 db.collection.find(<query>,{<arrayFi…

在投射中,使用$操作符和$elemMatch返回数组中第一个符合查询条件的元素。而在投射中使用$slice, 能够返回指定数量的数组元素。

定义

投射中使用$slice命令,指定查询结果中返回数组元素的数量。

语法

db.collection.find(<query>,{<arrayField: {$slice: <number to return}
)db.collection.find(<query>,{ <arrayField: {$slice: [ <number to skip>, <number to return>]}>}
)

其中<number to return>,指定了返回数组元素的数量,当定义为正值时,返回数组的前面几个元素,而定义负值时,返回数组后面的元素。如果定义的值大于数组长度,则返回数组中所有的元素。

<number to skip>,定义了自哪个元素开始,返回数组元素。与<number to return>定义一致,当定义正值时,从数组开头跳过指定数量的数组元素。当定义负值时,从数组第一个元素开始向后跳过指定数量的数组元素。这里<number to skip>的正数和负数,只是指定起点自第一个元素开始跳转的方向和跳动的次数。无论正数还是负数,使用<number to return>获取数组元素时,都是从数组的正向开始获取。

行为

在投射定义查询结果包含字段时,在内嵌文档的数组中使用$slice,内嵌文档只会返回slice定义的字段。

构建包含下面数据的inventory集合,其中details字段是文档类型,details.colors和details.sizes是文档details中的两个数组元素。

db.inventory.insertOne(
{ item: "socks", qty: 100, details: { colors: [ "blue", "red" ], sizes: [ "S", "M", "L"] } }
)

使用$slice返回colors字段中的第一个数组元素

db.inventory.find({},{qty: 1, "details.colors": { $slice: 1}}
)

返回结果

{"_id" : ObjectId("65b82e5b5943471b2e552d50"),"qty" : 100,"details" : {"colors" : [ "blue" ]}
}

在投射定义查询结果不包含字段时,在内嵌文档的数组中使用$slice, 内嵌文档会返回其他字段。

db.inventory.find({},{_id: 0, "details.colors": { $slice: 1}}
)

返回结果

{"item" : "socks","qty" : 100,"details" : {"colors" : [ "blue" ],"sizes" : [ "S", "M", "L" ]}
}

4.4版本前的数据库行为有差异,无论是定义包含字段还是不包含字段,投射中都会包含其他字段。

对视图的查询不支持$slice操作符。

4.4版本开始,使用find, findAndModify定义查询语句的投射中,不能将$slice应用到$操作符号中。下面的查询语句是错误的。

db.inventory.find({"instock.qty": {$gt:25}}, {"instock.$": {$slice:1}}
){"message" : "positional projection cannot be used with an expression or sub object","ok" : 0,"code" : 31271,"codeName" : "Location31271"
}

在文档数组字段使用$slice时,需要注意路径冲突

向集合inventory插入文档。其中instock是文档数组类型的数据。

db.inventory.insertOne({ item: "books", qty: 100, details: { colors: [ "blue", "red" ], sizes: [ "S", "M", "L"] },instock: [{warehouse: "A",qty:35},{warehouse: "B",qty:15},{warehouse: "C",qty:35}]}
)

构建针对instock的投射查询语句

db.inventory.find({},{ "instock": {$slice:1}, "instock.warehouse": 0})

因为instock和instock.warehouse定义的路径冲突,所以此语句无效。

{"message" : "Path collision at instock.warehouce remaining portion warehouce","ok" : 0,"code" : 31249,"codeName" : "Location31249"
}

应用

构建测试集合。向posts集合中插入两条数据,数据包含文档数组类型的字段comments.

db.posts.insertMany([{_id: 1,title: "Bagels are not croissants.",comments: [ { comment: "0. true" }, { comment: "1. croissants aren't bagels."} ]},{_id: 2,title: "Coffee please.",comments: [ { comment: "0. fooey" }, { comment: "1. tea please" }, { comment: "2. iced coffee" }, { comment: "3. cappuccino" }, { comment: "4. whatever" } ]}
])

构建查询语句,返回数组comments中前三个元素。

db.posts.find({}, {comments: {$slice:  3}})

返回数组comments中后面三个元素。

db.posts.find({}, {comments: {$slice:  -3}})

正向跳过1个元素,获取后面的三个元素

db.posts.find({}, {comments: {$slice: [1, 3]}})

反向跳过1个元素,获取后面的三个元素

db.posts.find({}, {comments: {$slice: [-1, 3]}})//返回结果
/* 1 */
{"_id" : 1,"title" : "Bagels are not croissants.","comments" : [{"comment" : "1. croissants aren't bagels."}]
},/* 2 */
{"_id" : 2,"title" : "Coffee please.","comments" : [{"comment" : "4. whatever"}]
}

这个语句的返回结果,就值得探讨了。正常理解可能会认为是跳过数组最后一个元素,然后获取最后一个元素前面的三个元素,即{ comment: "1. tea please" }, { comment: "2. iced coffee" }, { comment: "3. cappuccino" }。但这样获取的方向就是-3,而不是3了。在$slice中指定跳过几个元素时,指定获取元素的数量,只能是正数。也就表示获取元素的方向只能是正向。使用{$slice: [-1, 3]}时,表示从数组第一个元素开始,向后跳转一步,到达第四个元素,再以第四个元素作为起点,获得后面的3个元素。因为第四个元素后面没有数据了,所以只返回一个元素。

http://www.yayakq.cn/news/279056/

相关文章:

  • 贵州省建设学校网站首页皋兰县建设局网站
  • 做百度移动网站点网站建设的源代码有什么作用
  • 搬瓦工做网站好慢瑞安市建设工程质量监督站网站
  • 基本信息型网站有哪些专业沈阳网站制作
  • 如何查看网站ftp地址连云港企业网站建设
  • 《电子商务网站开发与管理》书籍网站建设公司利润分配
  • 深圳网站制作07551wordpress班级模板
  • c2c网站开发策划深圳网站制作问
  • 织梦做的网站在手机上显示国内重大新闻事件2023简短
  • 网站开发类网站模板下载html
  • 网络营销型网站建设外链发布平台大全
  • 求职网站开发多少钱centos 6.5 搭建wordpress
  • 宁波网站制作作dw制作网页的步骤
  • 网站群建设意见无锡网络推广服务
  • 简单的html网站开发做外单网站有哪些内容
  • 大气宽屏企业网站源码网页设计基础开题报告及网页流程图
  • word做网站连接东莞知名企业
  • 国外自建站怎么样深圳网站制作公司哪儿济南兴田德润优惠吗
  • 正在建设中的网站可算违规如何美化网站首页
  • 商丘行业网站建设开发公司做网站花钱吗
  • 定制企业网站建设制作沈阳网站优化
  • 公司让做网站违法微信客户管理系统
  • 做网站要学什么c语言wordpress seo怎么
  • 网站内页怎样做优化杭州网站建设外包公司
  • 佛山新网站建设哪家好wordpress 分页插件
  • dede个人网站模板WordPress能做门户网吗
  • 给钱做任务的网站怎么样才能建立网站平台
  • 各大网站的名字网站后台怎么修改前台的某个超链接网址
  • 如何建设网站兴田德润实惠企业微信网页版
  • 精品网站建设费用 要上磐石网络搜索引擎营销