mongo使用笔记
来源:互联网 发布:迅龙数据恢复怎么样 编辑:程序博客网 时间:2024/06/05 11:53
1.本地启动mongo /usr/local/mongodb/bin/mongod –dbpath=/usr/local/mongodb/data/db/
2.导出 #mongodump -h 127.0.0.1 -o /home/zhangxiaojing/
3.mongo导出库 # /usr/local/mongodb/bin/mongodump -h 127.0.0.1 -d zhao_manage(指定数据库) -o(导出所有表/集合) /home/zhangxiaojing/(导出位置)
4.还原导出的数据表mongoimport -d tank -c users –upsert /zhagnxiaojing
导出mongo数据表:
5.mongoexport -h IP –port 端口 -u 用户名 -p 密码 -d 数据库 -c 表名 -f 字段 -q 条件导出 –csv -o 文件名
mongoexport -d zhao_manage -c department_id -f id,name –type=csv -o /home/zhangxiaojing/department_id.csv
1.连接:mongo 127.0.0.1:8003
2.使用:show dbs
use admin
use tables 切换数据库
3. mongodb_修改器($inc/$set/$unset/$push/$pop/upsert
……)
对于文档的更新除替换外,针对某个或多个文档只需要部分更新可使用原子的更新修改器,能够高效的进行文档更新。更新修改器是种特殊的键,用来指定复杂的操作,比如增加、删除或者调整键,还可能是操作数组或者内嵌文档。
1.$inc
得出结论:修改器$inc
可以对文档的某个值为数字型(只能为满足要求的数字)的键进行增减的操作。
(这里有个问题:更新默认只对满足条件的记录集中第一个文档进行更新,那么使用$inc
修改器之后,还是一样吗?)
2.$set
用来指定一个键并更新键值,若键不存在并创建,可改变键的值类型,对于内嵌文档在使用$set
更新时,使用”.”连接的方式
db.c.update({"name":"toyota"},{"$set":{"size.width":7}}) "name":"toyota", "type" : "suv", "size" : { "height" : 8, "width" : 7, "length" : 15 }
3.$unset
从字面就可以看出其意义,主要是用来删除键。
得出结论:使用修改器$unset
时,不论对目标键使用1、0、-1或者具体的字符串等都是可以删除该目标键。
db.a.update({"uid" : "20120002","type" : "3"},{"$unset":{"desc":"sssssss"}})
4.数组修改器–$push
得出结论:$push
–向文档的某个数组类型的键添加一个数组元素,不过滤重复的数据。添加时键存在,要求键值类型必须是数组;键不存在,则创建数组类型的键。
–先push一个当前文档中不存在的键title
> db.c.update({"name" : "toyota"},{$push:{"title":"t1"}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1" ], "type" : "suv" }
–再向title中push一个值
> db.c.update({"name" : "toyota"},{$push:{"title":"t2"}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t2" ], "type" : "suv" }
–再向一个已经存在的键值非数组类型的键push一个值
> db.c.update({"name" : "toyota"},{$push:{"size.height":10}})Cannot apply $push/$pushAll modifier to non-array> db.c.update({"name" : "toyota"},{$push:{"name":"ddddddd"}})
Cannot apply $push/$pushAll
modifier to non-array
得出结论:$push
–向文档的某个数组类型的键添加一个数组元素,不过滤重复的数据。添加时键存在,要求键值类型必须是数组;键不存在,则创建数组类型的键
5.数组修改器–$ne/$addToSet
主要给数组类型键值添加一个元素时,避免在数组中产生重复数据,$ne
在有些情况是不通行的
6.数组修改器–$pop、$pull``$pop
从数组的头或者尾删除数组中的元素
–从数组的尾部删除 0
> db.c.update({"name" : "toyota"},{$pop:{"title":0}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t2" ], "type" : "suv" }
$pull
从数组中删除满足条件的元素
> db.c.update({"name" : "toyota"},{$pull:{"title":"t2"}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1", "t3" ], "type" : "suv" }
7.数组的定位修改器
在需要对数组中的值进行操作的时候,可通过位置或者定位操作符(”$”).数组是0开始的,可以直接将下标作为键来选择元素。
{"uid":"001",comments:[{"name":"t1","size":10},{"name":"t2","size":12}]}> db.c.find({"uid":"001"}){ "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {"name" : "t1", "size" : 10 }, { "name" : "t2", "size" : 12 } ] }> db.c.update({"uid":"001"},{$inc:{"comments.0.size":1}})> db.c.find({"uid":"001"}){ "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {"name" : "t1", "size" : 11 }, { "name" : "t2", "size" : 12 } ] }> db.c.update({"comments.name":"t1"},{$set:{"comments.$.size":1}})> db.c.find({"uid":"001"}){ "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {"name" : "t1", "size" : 1 }, { "name" : "t2", "size" : 12 } ] }
–若为多个文档满足条件,则只更新第一个文档。
8.upsert
upsert是一种特殊的更新。当没有符合条件的文档,就以这个条件和更新文档为基础创建一个新的文档,如果找到匹配的文档就正常的更新。
使用upsert,既可以避免竞态问题,也可以减少代码量(update的第三个参数就表示这个upsert,参数为true时)
> db.c.remove()> db.c.update({"size":11},{$inc:{"size":3}})> db.c.find()> db.c.update({"size":11},{$inc:{"size":3}},false)> db.c.find()> db.c.update({"size":11},{$inc:{"size":3}},true)> db.c.find(){ "_id" : ObjectId("5003ded6c28f67507a6df1de"), "size" : 14 }
9.save函数
1.可以在文档不存在的时候插入,存在的时候更新,只有一个参数文档。
2.要是文档含有”_id”,会调用upsert。否则,会调用插入。
> db.a.find(){ "_id" : ObjectId("50026affdeb4fa8d154f8572"), "desc" : "hello world1!", "num": 50, "sname" : "jk", "type" : "1", "uid" : "20120002" }> var o = db.a.findOne()> o.num = 5555> db.a.save(o)> db.a.find(){ "_id" : ObjectId("50026affdeb4fa8d154f8572"), "desc" : "hello world1!", "num": 55, "sname" : "jk", "type" : "1", "uid" : "20120002" }
1.要插入文件,也可以使用 db.post.save(document)。 如果不指定_id在文档中,然后将其 save() 方法和 insert()方法工作一样。如果指定_id,它会替换整个数据文件,其中包含_id 指定save()方法。
2.pretty() 方法
结果显示在一个格式化的方式,可以使用 pretty() 方法.
>db.mycol.find().pretty()
3.AND 在MongoDB中用法
>db.mycol.find({key1:value1, key2:value2}).pretty();
4.MongoDB中OR
db.mycol.find( { $or: [ {key1: value1}, {key2:value2} ] }).pretty()
5.ensureIndex() 方法
要创建一个索引,需要使用MongoDB 的ensureIndex()方法。
语法:
ensureIndex() 方法的基本语法如下
>db.COLLECTION_NAME.ensureIndex({KEY:1})
这里关键是要在其中创建索引,1是按升序排列的字段名称。要创建降序索引,需要使用-1。
6.sort() 方法
要在 MongoDB 中的文档进行排序,需要使用sort()方法。 sort() 方法接受一个文档,其中包含的字段列表连同他们的排序顺序。要指定排序顺序1和-1。 1用于升序排列,而-1用于降序。
语法:
sort() 方法的基本语法如下
>db.COLLECTION_NAME.find().sort({KEY:1})
- mongo使用笔记
- mongo 使用spring模板 笔记
- mongo使用笔记:查询及建立索引
- mongo笔记
- mongo 笔记
- mongo笔记
- mongo笔记
- mongo笔记
- mongo笔记
- mongo使用
- Mongo使用
- ycsb测试mongo笔记
- mongo学习笔记
- mongo入门------ 笔记一
- pomelo+mongo搭建笔记
- Mongo学习笔记(1)
- mongo笔记之监控
- mongo笔记之备份
- android多媒体总结
- Java基础——JSP(一)
- token和sign
- leetcode#5-Longest Palindromic Substring-java
- iOS 中的 Attribute
- mongo使用笔记
- 使用Calendar获取并修改时间
- 帆软 URL中文编码导致报表查询不到想要结果
- 基金a类和c类 收费什么区别
- 【哈哈日语】新编一册主要文法点(第一篇)
- JAVA写的计算器
- SecureCRT 自动断开连接的问题
- mysql生成一段时间的日期并插入表格,作为维护日期表
- PageRank 简介