Mongo权威指南(初级篇)

Wesley13
• 阅读 735

MongoDB 学习笔记 特点:

空间换时间

易于扩展

全文索引

SQL与NoSQL的合并,解决了SQL的效率

既有SQL的形式,又有NoSQL的自由

分片(Sharding) 将大的集合分割到不同的服务器(集群),MongoDB自动完成数据的分配,而且对应用层透明 集群

mongos 是用户与集群的交互点,用户可以把一个集群当成一台服务器

自动化,mongodb很多地方都实现了自动化,无需太多的人工干预,减少部署成本

安装部署 Mongo的安装很容易,从官网下载过来解压即可 默认数据库

  • admin 根数据库,主要提供用户认证,加入的用户会自动继承所有的数据库操作权限

  • config 分片操作时用来存储分片信息

  • local 该数据库中的数据永远不会被复制,可用来存储本地数据 CURD 插入:db.collectionname.insert( )

Mongo消息的最大长度是16M,注意批量插入的限制,当然也可以选择手工编译。解压的目录下有个bin目录,所有的东西都在这儿了

  • mongo mongo终端shell

  • mongod Mongo守护进程

  • mongos 路由器,负载均衡用

  • mongofiles mongo自带的文件系统GridFS的commandline管理工具

  • mongodump Mongo自带备份工具,类似于mysqldump 删除:`db.collectionname.remove({条件})

更新:db.collection.update({条件}, 数据)

** 批量更新是需要update的第四个参数为true

 `db.posts.update({'author.name':'tes'}, {'$set':{'author.name':'new name'}})`

修改器:修改使用$set,类似的操作有:

  • db.posts.update({'author.name':'tes'}, {'$inc':{'author.age':'1'}}) 用户的年龄+1

  • $push : 添加一条子记录

  • $addSet 不存在则添加

  • $each 一次添加多个

更新or插入 upsert 查询数据

db.collectionName.find({条件},{'显示列':1, ’不显示':0})

条件查询:

`db.collectionName.find({'age':{'$gt':19,'$lt':30}}) //查找年龄大于18小于30的

db.collection.find({'name':{'$in': ['zhangsan', 'lisi']}}) //类似于mysql的in 相反用$nin

collection.find({'$or': [ {'name': {'$in': ['zhangsan', 'lisi']}, {'age':{'$gt':18}} }]}) //查找名字为zhangsan或lisi,或年龄18以上的

$mod {'$mod': [5, 1]} 查找mod 5 余1的

$slice 查询子集切片

优化 索引 同MySQL一样,创建索引能加快查询速度

  • 创建索引 db.test.ensureIndex({'name': 1}, {'background': true })

  • 删除索引 dropIndexes

  • 地理空间索引 按两个维度进行搜索,比如经纬度,更酷的是还能按其他的指定形状进行索引

    db.map.find({'gps': {'$within' : {'$box': [10,20], [15,30]}}}) //建立矩形索引

    db.map.find({'gps': {'$within' : {'$center': [10,20], 5}}}) //圆形索引,可以用来做周边查询哦
    explain Mongo也支持explain对查询性能进行判断

聚合计算 MongoDB 本身支持count,group等聚合计算,但不建议使用,使用MapReduce效果会更好,在后台生成结果集会极大提高MapReduce的效率

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Easter79 Easter79
3年前
swap空间的增减方法
(1)增大swap空间去激活swap交换区:swapoff v /dev/vg00/lvswap扩展交换lv:lvextend L 10G /dev/vg00/lvswap重新生成swap交换区:mkswap /dev/vg00/lvswap激活新生成的交换区:swapon v /dev/vg00/lvswap
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MongoDB 分片管理(一)检查集群状态
一、检查集群状态1.1使用sh.status()查看集群摘要信息1、使用sh.status()可以查看分片信息、数据库信息、集合信息sh.status()如果数据块较多时,使用sh.status(true)又是输出会很多,就不会截断,要使用如下查看2、tooman
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这