Mongo小结
开启mongo的姿势:
cd /usr/local/mongo/bin(mongo的文件目录的bin目录下)
sudo ./mongod (开启mongo服务)
再新开一个终端
cd /usr/local/mongo/bin
sudo ./mongo (进入mongo数据库)
数据库操作:
use 数据库名字 使用/创建数据库
show dbs 查看所有的数据库
db.dropDatabase() 删除当前的数据库
db 查看当前数据库
集合操作:
- 不手动创建集合: 向不存在的集合中第⼀次加⼊数据时, 集合会被创建出来
- 手动创建结合:
- db.createCollection(name,options)
- db.createCollection("stu")
- db.createCollection("sub", { capped : true, size : 10 } )
- 参数capped: 默认值为false表示不设置上限,值为true表示设置上限
- 参数size: 当capped值为true时, 需要指定此参数, 表示上限⼤⼩,当⽂档达到上限时, 会将之前的数据覆盖, 单位为字节
- 查看集合:show collections
- 删除集合:db.集合名称.drop()
- 检查集合是否有上限: db.集合名.isCapped()
数据操作:
- 增
db.集合名.insert() db.user.insert({"name":"UZI", "age": "18" })
db.集合名.save() db.user.save()
- 改
db.集合名.update(<query> ,<update>,{multi: <boolean>})
参数query:查询条件
参数update:更新操作符
参数multi:可选, 默认是false,表示只更新找到的第⼀条记录, 值为true表示把满⾜条件的⽂档全部更新
db.user.update({"name":"UZI"},{"name":"MLXG"}) 将整个数据改为第二个{}里的内容
db.user.update({"name":"UZI"},{$set:{"name":"hys"}}) 将数据中的某个字段改为想改的值
db.user.update({},{$set:{gender:0}},{multi:true}) 将数据中的对应的值更改
- 删
db.集合名.remove(<query>,{justOne: <boolean>})
参数query:可选,删除的⽂档的条件
参数justOne:可选, 如果设为true或1, 则只删除⼀条, 默认false, 表示删除多条
db.user.remove({"name": "UZI"}, {justOne: <boolean>})
- 基本查询
⽅法find(): 查询
db.集合名称.find({条件⽂档})
⽅法findOne():查询,只返回第⼀个
db.集合名称.findOne({条件⽂档})
⽅法pretty(): 将结果格式化
db.集合名称.find({条件⽂档}).pretty()
- 条件查询
比较查询
- 等于: 默认是等于判断, 没有运算符
- ⼩于:
$lt (less than)
- ⼩于等于:
$lte (less than equal)
- ⼤于:
$gt (greater than)
- ⼤于等于:
$gte
不等于:
$ne
db.stu.find({ age:{ $gte:18 } }) 查询年龄大于等于十八的
db.stu.find({ time:{ $gte: ISODate("2018-05-11T13:58:51.122Z") } }) 时间大于条件的结果
- 逻辑运算查询
- 逻辑与
db.stu.find({ age:{ $gte:18 }, name:UZI })
- 逻辑或 or:使⽤$or, 值为数组
db.stu.find({ $or:[{age: { $gte:18 } }, { gender: true } ], name:UZI }) 查询年龄大于18或者性别为男,并且姓名为UZI的
p.p1 { margin: 0; font: 12px Courier; color: rgba(0, 0, 0, 1); -webkit-text-stroke: #000000 }
span.s1 { font-kerning: none }
- 范围运算查询
使⽤
$in
,$nin
判断数据是否在某个数组内
db.stu.find({ age : { $in: [10,20,30] } }) 查询年龄为10,20,30的结果
- 正则表达式查询
- 使⽤//或$regex编写正则表达式
db.stu.find( {name: /^andy/ } ) 查询姓名以andy开始的
db.stu.find( { name: {$regex: '768$' } } ) 查询姓名以768结尾的
- skip 和 limit
- limit( ) ⽤于读取指定数量的⽂档
- skip( ) ⽤于跳过指定数量的⽂档
db.stu.find().skip(10) 跳过前十条查询结果
db.stu.find().limit(10) 查询十条结果
- limit()和skip()同时使用,先使用skip在使用limit
db.stu.find().skip(10).limit(10) 和 db.stu.find().limit(10).skip(10) 查询结果相同 先跳过前十条,在查询十条
- 投影
在查询到的返回结果中, 只选择必要的字段,参数为字段与值, 值为1表示显示, 值为0不显 特别注意: 对于_id列默认是显示的, 如果不显示需要明确设置为0
db.stu.find( { }, {name:1,age:1 }) 查询结果只显示name和age字段
- 排序
- ⽅法sort(), ⽤于对 集进⾏排序,参数1为升序排列 参数-1为降序排列
db.stu.find().sort({ gender:1, age:-1 })
- 统计个数
- ⽅法count()⽤于统计结果集中⽂档条数
db.stu.find().count() 统计结果的次数
db.stu.count() 统计结果的次数
- 去重
- 方法distinct()用于对查询结果去重
db.stu.distinct("hometown", {age:{$gte:18} }) 对年龄大于18的结果以hometown去重
关闭mango的正确姿势:
use admin
db.shutdownServer()
mongoDB的备份与恢复
mongo备份语法:mongodump -h dbhost -d dbname -o dbdirectory
- -h:服务器地址,也可以指定端口号
- -d:需要备份的数据库名称
- -o:备份的数据存放位置,此目录中存放着备份出来的数据
实例:mongodump -h 192.168.196.128:27017 -d test1 -o ~/Desktop/test1bak
mongo恢复语法:mongorestore -h dbhost -d dbname --dir dbdirectory
- -h:服务器地址
- -d:需要恢复的数据库名称
- --dir:备份的数据的位置
实例:mongorestore -h 92.168.196.128:27017 -d test2 --dir ~/Desktop/test1bak/test1
mongoDB的导入和导出
导出语法: mongoexport -h dbhost -d dbname -c colname -o filename --type json/csv -f field
-h
: 服务器地址-d
: 数据库名-c
: 集合名-o
: 导出文件名--type
: 文件类型,默认json格式,可选数据类型json,csv-f
: 需要导出的字段,导出为json格式的数据时可以不指定导出哪些字段,默认全部,导出成csv文件是必须指定
示例:mongoexport -h 192.168.196.128:27017 -d test2 -c col1 -o test1_col1 [--type csv -f name,age,number]
导出语法: mongoimport -d dbname -c colname --file filename [--headerline --type json/csv -f field]
-h
: 服务器地址-d
: 数据库名-c
: 集合名-o
: 导出文件名--type
: 文件类型,默认json格式,可选数据类型json,csv-f
: 需要导出的字段,导出为json格式的数据时可以不指定导出哪些字段,默认全部,导出成csv文件是必须指定
示例:mongoexport -h 192.168.196.128:27017 -d test2 -c col1 -o test1_col1 --type csv -f name,age,number
Mongo小结的更多相关文章
- mongo 操作小结
这里总结一下mongo常用操作语句,分享给大家和我自己~ 打印系统,数据库,集合的信息 db.stats() 打印数据库状态 db ...
- mongo数据库使用小结
db.userId5555.aggregate({$unwind:"$tcjl"},{$match:{"_id":"0e549864-2a56-43c ...
- MongoDB使用小结:一些不常见的经验分享
最近一年忙碌于数据处理相关的工作,跟MongoDB打交道极多,以下为实践过程中的Q&A,后续会不定期更新补充. 另有<MongoDB使用小结:一些常用操作分享>,注:本文完成时Mo ...
- MongoDB使用小结:一些常用操作分享
本文整理了一年多以来我常用的MongoDB操作,涉及mongo-shell.pymongo,既有运维层面也有应用层面,内容有浅有深,这也就是我从零到熟练的历程. MongoDB的使用之前也分享过一篇, ...
- mongo 学习笔记
mysql语句 : ' ,,),(,,) mongo语句: db.}}).limit() db."}) db.}}) 条件操作符1 mongodb中的条件操作符有: (>) 大于 ...
- Canal使用小结
Canal使用小结 之前公司存在mysql数据同步mongo的需求,可以有多种实现方式,比如硬编码,发送消息等.公司选择的是Canal中间件,最近有空来研究下他的使用方式,对于mysql数据变更监听有 ...
- 数据库新秀 postgresql vs mongo 性能PK
前几天看了一篇文章<High Performance JSON PostgreSQL vs. MongoDB> 发布在Percona Live Europe 2017 作者是<Dom ...
- mongo的身份验证和授权
问题来源 刚装好的mongo,准备登陆进去测一把的,结果就给我报这个错,鄙人是新手,还不太清楚这个,现学一下~ Mongo的身份验证 在上一篇安装mongo的博客中(https://www.cnblo ...
- Mongo DB命令简介
引言 最近在学习MongoDB 总结了一些命令及常用的东西做整理 常用目录文件介绍 mongod 数据库部署命令 mongo 连接mongodb数据库而使用的命令 mongoimport 导入 ...
随机推荐
- ubuntu下安装RabbitMQ
ubuntu下安装RabbitMQ 安装erlang 由于rabbitMq需要erlang语言的支持,在安装rabbitMq之前需要安装erlang sudo apt-get install erla ...
- 老师问学生while判断
老师问学生,这道题你会做了吗?如果学生答"会了(y)",则可以放学.如果学生不会做(n),则老师再讲一遍,再问学生是否会做了...... (1)直到学生会为止,才可以放学. (2) ...
- leetcode132:4sum
题目描述 给出一个有n个元素的数组S,S中是否有元素a,b,c和d满足a+b+c+d=目标值?找出数组S中所有满足条件的四元组. 注意: 四元组(a.b.c.d)中的元素必须按非降序排列.(即a≤b≤ ...
- C的输入&输出
格式说明符 输出 %d整型输出,%ld长整型输出, %o以八进制数形式输出整数, %x以十六进制数形式输出整数,或输出字符串的地址. %u以十进制数输出unsigned型数据(无符号数).注意:%d与 ...
- java实现科研信息管理系统
一.前言 本学期学习了JAVA语言,在学期的结束,写一个有操作界面,与数据库关联的管理系统,用来巩固自己本学习所学的知识.用到的知识:JAVA基础,JAVA界面设计(GUI),Oracle数据库(需要 ...
- 经典c程序100例==61--70
[程序61] 题目:打印出杨辉三角形(要求打印出10行如下图) 1.程序分析: 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 2.程序源代码: main() ...
- ubutun 服务器配置jupyter notebook
由于能力有限,学习机器学习时候发现,自己的电脑带不起来,所以想起了服务器,选择的是阿里的ubutun服务器,所以希望能够 使用jupyter notebook,看到网上一大片,配置和好久,才成功,在这 ...
- 为什么人们总是认为epoll 效率比select高!!!!!!
今天看公司代码时,发现代码里面使用的事清一色的代码使用epoll, 所以就得说一说了:宏观看一看epoll 和select的实现: select原理概述 调用select时,会发生以下事情: 从用户空 ...
- new与malloc的10点区别(转)
1. 申请的内存所在位置 new操作符从自由存储区(free store)上为对象动态分配内存空间,而malloc函数从堆上动态分配内存.自由存储区是C++基于new操作符的一个抽象概念,凡是通过ne ...
- netty简介2
作者:知乎用户 链接:https://www.zhihu.com/question/24322387/answer/282001188 来源:知乎 著作权归作者所有.商业转载请联系作者获得授权,非商业 ...