Mongo中的数组操作
当前mongo中有这么一条数据
book是一个数组,在他后面添加一条数据
{
"_id" : ObjectId("5721f504d1f70435632b5ce7"),
"qqqqq" : 5.0,
"list" : {
"school" : "驻马店第一高级中学",
"age" : 22.0,
"name" : "qiaoansheng"
},
"book" : ["C#大全", "干你妹三千"]
}
db.ansheng.update({"_id":ObjectId("5721f504d1f70435632b5ce7")},{"$push":{"book":"mongo权威指南"}})
执行完成后 mongo权威指南 完美的添加到了,这个数组的后面
/* 0 */
{
"_id" : ObjectId("5721f504d1f70435632b5ce7"),
"qqqqq" : 5.0,
"list" : {
"school" : "驻马店第一高级中学",
"age" : 22.0,
"name" : "qiaoansheng"
},
"book" : ["C#大全", "干你妹三千", "mongo权威指南"],
"MyBook" : [{
"bookName" : "干你妹三千",
"money" : 188.0
}, {
"bookName" : "干你妹三千",
"money" : 188.0
}, {
"bookName" : "mongo权威指南",
"money" : 188.0
}]
}
MyBook是一个集合,我要在这个集合后面追加一条数据
db.ansheng.update({"_id":ObjectId("5721f504d1f70435632b5ce7")},{"$push":{"MyBook":{"bookName":"在绝望中寻找希望","money":188}}})
在集合或者数组后面追加多条数据
db.ansheng.update({"name":"qiao"},{"$push":{"book":{"$each":["在绝望中寻找希望","C#大全"]}}})
这是个数组后面追加多个数据,集合类似
{
"_id" : ObjectId("5722941242c4872428edcc89"),
"name" : "qiao",
"book" : ["在绝望中寻找希望", "C#大全"],
"Books" : [{
"name" : "在绝望中寻找希望",
"money" : 188.0
}, {
"name" : "C#大全",
"money" : 77.0
}]
}
book是一个数组,向这个数组后面追加一本书,如果这本书存在则不用追加,如果不存在则追加
db.ansheng.update({"book":{"$ne":"在绝望中寻找希望"}},{"$push":{"book":"在绝望中寻找希望"}})
db.ansheng.update({"name":"qiao"},{"$addToSet":{"book":"在绝望中寻找希望1"}})
$addToSet 配合 $each 可以插入多条数据
db.ansheng.update({"name":"qiao"},{"$addToSet":{"book":{"$each":["在绝望中寻找希望4","在绝望中寻找希望3"]}}})
删除一个元素
db.ansheng.update({"name":"qiao"},{"$pop":{"book":1}}) 删除最后一个元素
db.ansheng.update({"name":"qiao"},{"$pop":{"book":-1}})删除第一个元素
删除指定的元素
db.ansheng.update({"name":"qiao"},{"$pull":{"book":"在绝望中寻找希望4"}})
$pull会把所有匹配到的数据都删除掉,而不是只删除一个
添加和删除总结
在数组后面追加数据
db.ansheng.update({"_id":ObjectId("5721f504d1f70435632b5ce7")},{"$push":{"book":"mongo权威指南"}})
在集合后面追加数据
db.ansheng.update({"_id":ObjectId("5721f504d1f70435632b5ce7")},{"$push":{"MyBook":{"bookName":"在绝望中寻找希望","money":188}}})
在数组后面追加多条数据
db.ansheng.update({"name":"qiao"},{"$push":{"book":{"$each":["在绝望中寻找希望","C#大全"]}}})
在集合后面追加多条数据
db.ansheng.update({"name":"qiao"},{"$push":{"Books":{"$each":[{"name":"在绝望中寻找希望","money":188},{"name":"C#大全","money":77}]}}})
在数组后面追加数据,只有不存在才会追加
db.ansheng.update({"book":{"$ne":"在绝望中寻找希望"}},{"$push":{"book":"在绝望中寻找希望"}})
db.ansheng.update({"name":"qiao"},{"$addToSet":{"book":"在绝望中寻找希望1"}})
db.ansheng.update({"name":"qiao"},{"$addToSet":{"book":{"$each":["在绝望中寻找希望4","在绝望中寻找希望3"]}}})追加多条数据
删除数组中的第一个或者最后一个元素
db.ansheng.update({"name":"qiao"},{"$pop":{"book":1}}) 删除最后一个元素
db.ansheng.update({"name":"qiao"},{"$pop":{"book":-1}})删除第一个元素
删除指定的元素
db.ansheng.update({"name":"qiao"},{"$pull":{"book":"在绝望中寻找希望4"}})
数组中的查询
{"_id" : ObjectId("572aba3d734e0336c344e8bf"),"name" : ["C#大全", "权威指南", "我的梦想"]}
{"_id" : ObjectId("572aba3d734e0336c344e8c0"),"name" : ["权威指南", "我的梦想", "C#大全"]}
{"_id" : ObjectId("572aba3d734e0336c344e8c1"),"name" : ["我的梦想", "C#大全", "权威指南"]}
{"_id" : ObjectId("572aba3d734e0336c344e8c2"),"name" : ["C#大全", "权威1指南", "我的梦想"]}
{"_id" : ObjectId("572aba3d734e0336c344e8c3"),"name" : ["C#大全", "我的梦想"]}
现在有这么一个文档
db.as1.find({name:"C#大全"})//匹配到全部的数据
db.as1.find({name:"C#大全",name:"权威指南"})//匹配到三条数据
{"_id" : ObjectId("572aba3d734e0336c344e8bf"),"name" : ["C#大全", "权威指南", "我的梦想"]}
{"_id" : ObjectId("572aba3d734e0336c344e8c0"),"name" : ["权威指南", "我的梦想", "C#大全"]}
{"_id" : ObjectId("572aba3d734e0336c344e8c1"),"name" : ["我的梦想", "C#大全", "权威指南"]}
$all
要找到既有 "C#大全" 又有 "权威指南" 就要使用$all
db.as1.find({name:{"$all":["C#大全", "权威指南"]}})
但是我发现这个和上面那一个查询条件是等价的
查询特定位置的元素
db.as1.find({"name.1":"权威指南"})
db.as1.find({"name.0":"C#大全"})
$size
$size对于查询数组来说也是分的有用,他可以查询特定长度的数组
db.as1.find({name:{"$size":2}})
$slice
$slice操作符可以返回某个键匹配的数组元素的一个子集
{"_id" : ObjectId("572aba3d734e0336c344e8bf"),"name" : ["C#大全", "权威指南", "我的梦想"]}
db.as1.find({"_id" : ObjectId("572aba3d734e0336c344e8bf")},{name:{"$slice":2}})
find有两个参数第一个是用来匹配数据的,第二个是用来设置返回的数据的
name是一个数组 $slice返回这个数组中前2个元素
{"$slice":2} 前两个
{ "_id" : ObjectId("572aba3d734e0336c344e8bf"), "name" : [ "C#大全", "权威指南"] }
{"$slice":-2} 后两个
{ "_id" : ObjectId("572aba3d734e0336c344e8bf"), "name" : [ "权威指南", "我的梦想" ] }
{"$slice":[2,3]} 第2个之后的到第3个为止,如果没有第三个,则返回空
{ "_id" : ObjectId("572aba3d734e0336c344e8bf"), "name" : [ "我的梦想" ] }
{"$slice":[3,4]}
{ "_id" : ObjectId("572aba3d734e0336c344e8bf"), "name" : [ ] }
Mongo中的数组操作的更多相关文章
- mongo二维数组操作
有2个嵌套的数组: 如果我想查询comments里score大于5的记录: testProvider.find({"comments.score":{"$gt" ...
- JavaScript jQuery 中定义数组操作及数组操作
1.认识数组 数组就是某类数据的集合,数据类型可以是整型.字符串.甚至是对象 Javascript不支持多维数组,但是因为数组里面可以包含对象(数组也是一个对象),所以数组可以通过相互嵌套实现类似多维 ...
- javascript中的数组操作
1.数组的创建 var arrayObj = new Array(); //创建一个数组 var arrayObj = new Array([size]); //创建一个数组并指定长度,注意不是上限, ...
- web 开发之js---js 中的数组操作
js数组元素的添加和删除一直比较迷惑,今天终于找到详细说明的资料了,先给个我测试的代码^-^var arr = new Array();arr[0] = "aaa";arr[1] ...
- Java中的数组操作进阶
package com.mi.array; import java.util.Arrays; /** * System.arraycopy(i, 0, j, 0, i.length);这种复制会覆盖目 ...
- Java 中的数组操作
前言 在Java中,有很多封装好的类可以用来操纵数组(排序,复制等等),使得数组使用起来非常的方便.这就是高级语言带来的好处. 代码示例 - 一维数组 package test; import jav ...
- js中的数组操作
<!DOCTYPE HTML> <html > <head> <meta http-equiv="Content-Type" conten ...
- php数组操作集锦- 掌握了数组操作, 也就掌握了php
参考下面的文章, 是很好的: http://www.cnblogs.com/staven/p/5142515.html http://pcwanli.blog.163.com/blog/static/ ...
- ES6之数组操作
es6中对于数组操作添加了4种方法: 1.map —— 映射(一个对应一个) 2.reduce —— 汇总(多个出来一个) 3.filter —— 过滤 4.forEach —— 迭代/循环. 1.m ...
随机推荐
- html 绘图渐变和图片填充
包括线性渐变和径向渐变 <!DOCTYPE html> <html> <head lang="en"> <meta charset=&qu ...
- Transactional topologies —— 事务拓扑
事务拓扑是怎么回事? Storm guarantees that every message will be played through the topology at least once. St ...
- FFMPEG解码流程
FFMPEG解码流程: 1. 注册所有容器格式和CODEC: av_register_all() 2. 打开文件: av_open_input_file() 3. 从文件中提取流信息: av_f ...
- html ul 里 能放其他标签吗,比如h3、p?
按标准的话,ul 里面应该只能放li,不过看见同事有的放了h3.p这些,这样到底可不可以? <ul>里面只能放<li>.但是<li>里面可以放<h*> ...
- Qt OpenCV Support Image Type 支持读写的图像格式
Qt 支持的图片格式如下: Format Description Qt's support BMP Windows Bitmap Read/write GIF Graphic Interchange ...
- hdu 最大报销额
本题也是一个背包的问题,我觉得这道题的核心就是根据精确度将浮点型转化为整型然后利用动态规划进行求解,注意对题意的理解,有3种支票是不能够报销的. 我开始照着这个思路进行思考,但是敲出来的第一个代码居然 ...
- 使用安捷伦波形编辑软件产生GK101 任意波数据文件的方法(支持手绘)
软件安装包下载地址: 链接: http://pan.baidu.com/s/1bn8Lmhx 密码: v5xz 一.安捷伦IO套件安装 1.将压缩包解压,首先双击IOLibSuite_16_3_179 ...
- JavaScript系列:函数调用方式
有关JS的问题,持续更新.. 一,函数调用的4种方式 1,函数调用模式 //下面这种模式叫 “函数调用模式”:窗后window来调用 //函数调用四种方式的基础 //这tm不就是作用域this的问题吗 ...
- DS实验题 Missile
题目: 提示:并没有精度问题. 原题 NOIP2010 导弹拦截 思路 设源点为A(x1, y1)和B(x2, y2). 第一步,用结构体存节点,包括以下元素: 1.横坐标x 2.纵坐标y 3.节点和 ...
- Memcached 笔记与总结(1)Linux(CentOS 6.6) 和 Windows(7)下安装与配置 Memcached (1.4.24)与 Memcached 基础命令
Memcached 官方网站:http://memcached.org/ 官网对其的描述是: What is Memcached? Free & open source, high-perfo ...