Mongodb 的基本使用
一、cmd连接mongodb 服务
进入mongodb的bin目录下:[D:\mongodb3.2.5\bin]$ mongo 127.0.0.1:27017
常用查询:
show dbs 查看所有数据库
use dbName 进入当前数据库
show tables 查看该数据库下的集合
二、curd操作
查询:
1.查全部:db.mydb2_collection.find();
2.查询一条:db.mydb2_collection.findOne();
插入:db.mydb2_collection.insert({m:1});
修改:db.mydb_collection.update({x:1},{x:999});
删除:db.mydb_collection.remove({c:2});
三、索引
优点:可以加快与所有相关的查询速度
缺点:增加磁盘空间,降低写入性能
索引类型:
id索引:自动创建的
单键索引:
多键索引:db.mydb2_collection.insert({x:[1,2,3,4,5]});
复合索引:当我们的查询条件不知一个的时候,就需要建立复合索引
db.mydb2_collection.ensureIndex({x:1,y:1}); 创建
db.mydb2_collection.find({x:1,y:2}); 使用
过期索引:1.在一段时间后会过期的索引 2、在索引过期后相应的数据会被删除
使用场景:适合存储在一些时间后会失效的数据比如用户登录信息,存储的日志
创建方式:
注意:存储在过期索引的字段必须是指定时间类型,必须是ISODate或者ISODate数组,不能使用时间戳,否则不能自动删除。
如果是数组,则按照最小的时间进行删除
过期索引不是复合索引
删除时间是不精确的(删除过程是后台程序没60秒执行一次的进程操作的,删除操作本身也需要时间) 最小时间差60秒
全文索引:对字符串与字符串数组创建全文可搜索的索引
插入数据:db.mydb2_collection.insert({arrticle:"aa bb cc gg hh"});
查询:db.mydb2_collection.find({$text:{$search:"aa"}});
db.mydb2_collection.find({$text:{$search:"aa bb ee"}}); //多关键字 或者 的关系
db.mydb2_collection.find({$text:{$search:"aa bb -cc"}}); //不包含cc
db.mydb2_collection.find({$text:{$search:"\"aa\"\"bb\"\"cc\""}});//多关键字 且的关系
全文索引相似度:
查询:db.mydb2_collection.find({$text:{$search:"aa bb"}},{score:{$meta:"textScore"}});
db.mydb2_collection.find({$text:{$search:"aa bb"}},{score:{$meta:"textScore"}}).sort({score:{$meta:"textScore"}//排序
索引的属性:
name属性
指定名字创建索引:db.mydb2_collection.ensureIndex({c:1,y:1},{name:"normal_index"});
根据名字删除索引:db.mydb2_collection.dropIndex("normal_index");
unique索引的唯一性:
db.mydb2_collection.ensureIndex({m:1,n:1},{unique:true})
作用:在做添加时如果存在就不插入,否则插入
稀疏性:sparse
创建:db.mydb2_collection.ensureIndex({m:1},{sparse:true});
查询强制使用索引:db.mydb2_collection.find({m:{$exists:false}}).hint("m_1");
地理位置索引:
2d:
创建2d平面索引: db.mydb_location.ensureIndex({w:"2d"});
位置表示方式:经纬度[经度,纬度]
取值范围:经度:[-180,180] 纬度[-90,90]
插入:db.mydb_location.insert({w:[2,1]});
near查询:
查查与[1,1]最近的点:db.mydb_location.find({w:{$near:[1,1]}});
查询与[1,1]相近 10的点:db.mydb_location.find({w:{$near:[1,1],$maxDistance:10}});
形状查询 $geoWithin:
矩形 $box: db.mydb_location.find({w:{$geoWithin:{$box:[[0,0],[2,2]]}}});
圆形$center:db.mydb_location.find({w:{$geoWithin:{$center:[[0,0],2]}}});
多边形$polygon:db.mydb_location.find({w:{$geoWithin:{$polygon:[[0,0],[2,2],[0,2]]}}});
geoNear查询:
db.runCommand({geoNear:"mydb_location",near:[1,2],maxDistance:3,num:1});
2dsphere索引球面地理位置:
四、安全机制
MongoDB安全机制:
1.物理分离(最安全):不现实
2.网络隔离
3.防火墙的隔离:给固定的ip访问权限
4.用户名和密码
创建用户
db.createUser({user:"jalja",pwd:"jalja",roles:[{role:"userAdmin",db:"mydb"},{role:"read",db:"test"}]});
权限:read、readWrite、dbAdmin、dbOwner、userAdmin
在mongo.conf 中添加 auth =true 开启权限认证
使用 用户名密码连接:mongo 127.0.0.1:27017 -u jalja -p jalja
mongodb 的角色
1、数据库角色
2、集群角色
3、数据备份角色
4、其他特殊权限
Mongodb 的基本使用的更多相关文章
- 【翻译】MongoDB指南/聚合——聚合管道
[原文地址]https://docs.mongodb.com/manual/ 聚合 聚合操作处理数据记录并返回计算后的结果.聚合操作将多个文档分组,并能对已分组的数据执行一系列操作而返回单一结果.Mo ...
- 【翻译】MongoDB指南/CRUD操作(四)
[原文地址]https://docs.mongodb.com/manual/ CRUD操作(四) 1 查询方案(Query Plans) MongoDB 查询优化程序处理查询并且针对给定可利用的索引选 ...
- 【翻译】MongoDB指南/CRUD操作(三)
[原文地址]https://docs.mongodb.com/manual/ CRUD操作(三) 主要内容: 原子性和事务(Atomicity and Transactions),读隔离.一致性和新近 ...
- 【翻译】MongoDB指南/CRUD操作(二)
[原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(二) 主要内容: 更新文档,删除文档,批量写操作,SQL与MongoDB映射图,读隔离(读关 ...
- 【翻译】MongoDB指南/CRUD操作(一)
[原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(一) 主要内容:CRUD操作简介,插入文档,查询文档. CRUD操作包括创建.读取.更新和删 ...
- CRL快速开发框架系列教程十二(MongoDB支持)
本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...
- MongoDB系列(二):C#应用
前言 上一篇文章<MongoDB系列(一):简介及安装>已经介绍了MongoDB以及其在window环境下的安装,这篇文章主要讲讲如何用C#来与MongoDB进行通讯.再次强调一下,我使用 ...
- MongoDB系列(一):简介及安装
什么是MongoDB MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为应用提供可扩展的高 ...
- [原]分享一下我和MongoDB与Redis那些事
缘起:来自于我在近期一个项目上遇到的问题,在Segmentfault上发表了提问 知识背景: 对不是很熟悉MongoDB和Redis的同学做一下介绍. 1.MongoDB数组查询:MongoDB自带L ...
- 用MongoDB分析合肥餐饮业
看了<从数据角度解析福州美食>后难免心痒,动了要分析合肥餐饮业的念头,因此特地写了Node.js爬虫爬取了合肥的大众点评数据.分析数据库我并没有采用MySQL而是用的MongoDB,是因为 ...
随机推荐
- Ajax参数详解
1.url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. 2.type: 要求为String类型的参数,请求方式(post或get)默认为get.注意其他http请求方法,例如 ...
- swift禁用webView对H5中数字,链接,日期,地址,电话号码做解析
showWebView.dataDetectorTypes = .None //swift禁用webView对H5中数字,链接,日期,地址,电话号码做解析 其UIDataDetectorTypes属性 ...
- MIPS ABI n32意味着什么?
ABI是应用程序二进制接口的简称,用于标识处理器的工作模式及规范目标文件的编码格式. MIPS指令集架构自MIPS3起正式支持64位工作模式,故编码可以遵从o32(o意思是old).n32(n意思是n ...
- SQL中的共享锁分析及如何解锁
1.1.1 摘要 在系统设计过程中,系统的稳定性.响应速度和读写速度至关重要,就像12306.cn那样,当然我们可以通过提高系统并发能力来提高系统性能总体性能,但在并发作用下也会出现一些问题,例如死锁 ...
- [Java基础]java的main函数
1.main函数详解 main在编程中的形式:public static void main(String[] args) { - } public : 公共的. 权限是最大,在任何情况下都可以访问. ...
- 开始VS 2012中LightSwitch系列的第4部分:太多信息了!使用查询来排序和筛选数据
[原文发表地址] Beginning LightSwitch in VS 2012 Part 4: Too much information! Sorting and Filtering Data ...
- 让.NET xml序列化支持Nullable
.NET的序列化,关于契约类的生成我们都是通过xsd.exe,对于值类型的可空判断是通过声明同名+Specified的bool属性来判断,比如: public class Person { publi ...
- Win10 UWP应用发布流程
简介 Win10 UWP应用作为和Win8.1 UAP应用不同的一种新应用形式,其上传至Windows应用商店的流程也有了一些改变. 这篇博文记录了我们发布一款Win10 UWP应用的基本流程,希望为 ...
- 推荐一些常用感觉不错的jQuery插件
转:http://www.cnblogs.com/v10258/p/3263939.html JQuery插件繁多,下面是个人在工作和学习中用到感觉不错的,特此记录. UI: jquery UI(官方 ...
- java中的Static class
Java中的类可以是static吗?答案是可以.在java中我们可以有静态实例变量.静态方法.静态块.类也可以是静态的. java允许我们在一个类里面定义静态类.比如内部类(nested class) ...