mongodb搭建和基本语法
下载安装包
安装及基本语法
http://jingyan.baidu.com/article/ed15cb1b52b8661be2698162.html
基本语法
插入:
for(i=3;i<100;i++) db.table.insert({x:i})
查询:
db.table.find().skip(3).limit(2).sort({x:1}) // 跳过前三条,查询两条数据,并按x的正序排序
db.table,find().count() // 查询数据数量
db.table.find({m:{$exists:true}}) // 查询存在m字段的数据,true存在,false不存在
db.table.find({m:{$exists:true}}).hint("index_name") // 查询时强制使用索引
更新:
db.table.update({x:1},{x:999},true,true) // 第三个参数表示如果更新的数据不存在,则插入一条数据;更新时默认更新符合条件的第一条数据,第四个参数为true,则更新所有符合条件的数据
db.table.update({z:100},{$set:{y:100}}) // 更新部分数据
删除:
db.table.remove({x:1}) // 默认删除所有符合条件的数据
db.table.remove({}); // 删除集合中的所有数据
db.table.drop() // 删除表中所有的数据,并把表删除
db.dropDatabase() // 删除数据库
索引:
db.table.ensureIndex({x:1}) // 创建单键索引
db.table.ensureIndex({x:1,y:-1}) // 创建复合索引,1和-1表示排序
db.table.ensureIndex({x:1},{expireAfterSeconds:30}) // 创建过期索引,一段时间后插入的数据自动删除,expireAfterSeconds单位是秒
过期索引的限制:
1、存储在过期索引字段的值必须是指定的时间类型,ISODate或者ISODate数组,不能用时间戳(new Date())
2、如果指定了ISODate数组,则按照最小的时间进行删除
3、过期索引不能是复合索引
4、删除时间不是精确的,删除过程是有后台程序每60s跑一次,而且上次也是需要一些时间
db.table.getIndexes() // 查询索引
db.table.dropIndex("index_name") // 删除索引,index_name是索引的名字
db.table.ensureIndex({x:1},{name:"index_name"}) // 自定义索引的名字,如果没有第二个参数,mongo会给索引一个默认名字
db.table.ensureIndex({x:1},{unique:true}) // 唯一索引,唯一性
db.table.ensureIndex({x:1},{sparse:true}) // 稀疏索引,稀疏性,不必为不存在x字段的数据创建索引,如果强制使用索引查找不存在x的数据,则查不到数据
全文索引
db.table.ensureIndex({key1:"text",key2:"text"}) // 创建全文索引,value为text
db.table.ensureIndex({"$**":"text"}) // 表示对集合中所有字段,创建全文索引
db.table.find({$text:{$search:"coffee"}}) // 查找全文索引
db.table.find({$test:{$search:"aa bb cc"}}) // 查找多个关键词,用空格分开,“或”查询,含有其中一个
db.table.find({$test:{$search:"\"aa\" \"bb\" \"cc\""}}) // 查找多个关键词,“与“查询,都包含,用引号把关键词包裹起来
db.table.find({$test:{$search:"aa bb -cc"}}) // 查找多个关键词,但不包含cc
db.table.find({$test:{$search:"aa bb"}}, {score:{$meta:"textScore"}}).sort({score:{$meta:"textScore"}}) // 查找相似度并排序,得分越高,越相似
全文索引的限制:
1、每次查询,只能指定一个$text查询
2、$text查询不能出现在$nor查询中
3、查询中如果包含了$text,hint不再起作用
4、mongoDB全文索引还不支持中文
地址位置索引:
2D索引:平面地址位置索引
db.table.ensureIndex({w:"2d"}) // 值是2d
db.table.insert({w:[经度,纬度]})
db.table.find({w:{$near:[1,1],$maxDistance:10}}) // 10个点范围内,查询距离某个点最近的点
db.table.find({w:{$geowithin:{$box:[[0,0],[3,3]]}}}) // 查询某个形状内的点
1、$body:矩形
{$body:[[x1,y1],[x2,y2]]} // 左边界和右边界
2、$center:圆形
{$center:[[x1,y1],r]} // 圆心位置和半径
3、$polygon:多边形
{$polygon:[[x1,y1],[x2,y2],[x3,y3],……]}
2Dsphere索引:球面地理位置索引
db.table.ensureIndex({w:"2dsphere"})
GeoJSON:描述一个点,一条直线,多边形等形状
格式:{type:"",coordinates:[<coordinates>]}
geoNear查询:
db.runCommand({geoNear:<collection>,near:[x,y],minDistance:(对2d索引无效),maxDistance:10,num:2(查询个数)})
备份策略
命令行备份:mongodump/mongorestore mongodump将mongodb的数据导出至BSON文件,mongorestore将BSON文件的数据导入到mongodb中
文件系统备份
Backup服务
MongoDB中条件操作符有:
- (>) 大于 - $gt
- (<) 小于 - $lt
- (>=) 大于等于 - $gte
- (<= ) 小于等于 - $lte
db.table.find({age : {$lt :24, $gt : 17}})
mongodb搭建和基本语法的更多相关文章
- express + mongodb 搭建一个简易网站(二)
express + mongodb 搭建一个简易网站 (二) 在搭建网站(一)中,实现了简单的路由功能,这离一个完整的网站还差的有点远,继续撸代码吧. 1.首先在根目录下新建一个views文件夹,用来 ...
- 用“MEAN”技术栈开发web应用(三)用mongodb搭建数据库
上一篇介绍了如何用express搭建起服务端MVC的开发架构,本篇我们来详细介绍一下这个Model层,也就是数据库访问层.包含如何使用mongodb搭建数据库,以及如何使用mongoose来访问数据. ...
- Python中使用Flask、MongoDB搭建简易图片服务器
主要介绍了Python中使用Flask.MongoDB搭建简易图片服务器,本文是一个详细完整的教程,需要的朋友可以参考下 1.前期准备 通过 pip 或 easy_install 安装了 pymong ...
- mongodb命令行基础语法
首先是安装并配置mongodb,这个请自行百度,安装完成后打开cmd命令输入mongo.我们现在先做一个例子吧,假设有一个班级叫c1,里面有若干个人,里面的人有姓名.年龄.性别和班级,我们分别对他们进 ...
- 用Node.JS+MongoDB搭建个人博客(页面模板)(五)(结束)
<差不多先生> 我是差不多先生,我的差不多是天生.也代表我很天真,也代表我是个闲人.这差不多的人生,总是见缝插针. 求学的道路上总是孤独的,即使别人不理解我,认为我是奇葩!但没关系,我会坚 ...
- 从无到有,用Nodejs+express+mongodb搭建简易登陆系统
前端处理server表示很蛋疼,初学Node,虽然感觉异常强大,但是学起来还是有些吃力的,Node是工具,它不是万能的,搭建一个系统还是需要借助其他一些工具,对于我这个没怎么接触server的前端来说 ...
- express + mongodb 搭建一个简易网站 (四)
express + mongodb 搭建一个简易网站 (四) 目前网站整体页面都已经能全部展示了,但是,整个网站还有两个块需要做完才能算完整,一个连接数据库,目前网站上的数据都是抓取的本地假数据,所以 ...
- express + mongodb 搭建一个简易网站 (三)
express + mongodb 搭建一个简易网站 (三) 前面已经实现了基本的网站功能,现在我们就开始开搞一个完整的网站,现在整个网站的UI就是下面的这个样子. 我们网站的样子就照着这个来吧. 1 ...
- express + mongodb 搭建一个简易网站(一)
express + mongodb 搭建一个简易网站(一) 前言:后台使用node.js的express框架,数据库使用mongodb,模板使用ejs.大概就这些. 开始第一个简易网站之旅吧.... ...
随机推荐
- POCO库——Foundation组件之日期时间DateTime
日期时间DateTime:内部提供多个设计计时器.日期.时区.时间戳等: Clock.h :Clock时钟计时类,_clock:Int64类型时钟值,CLOCKVAL_MIN.CLOCKVAL_MAX ...
- 谈谈SQL 语句的优化技术
https://blogs.msdn.microsoft.com/apgcdsd/2011/01/10/sql-1/ 一.引言 一个凸现在很多开发者或数据库管理员面前的问题是数据库系统的性能问题.性能 ...
- MVVM页面跳转 技巧性标记
刚学MVVM 百度了很多概念性的东西 也参考了网上的例子 基本有了了解 但是我发现 我做了一个登录页面以后 我跳转咋办呢? VM里面咋做跳转? 问了一下其他的群友得到了一些启发.感谢“上海*松” 我仅 ...
- (转) Wp7 list 中列表项多样化的解决方案-Custom DataTemplateSelector
本文转自: http://www.cnblogs.com/sonyye/archive/2012/03/03/2378825.html 在这篇文章中,我将解释如何在Windows Phone 7中创建 ...
- nodejs复习02
process 这个模块是单线程的,无法完全利用多核CPU 基本信息 //程序目录 process.cwd(); //应用程序当前目录 process.chdir('/home'); //改变应用程序 ...
- UVA - 11604 General Sultan 题解
题目大意: 有若干模式串,将某些模式串拼接起来(一个可以使用多次)形成一个长模式串,判断能否有两种或更多种不同的拼法拼成相同的模式串. 思路: 神奇的构图,暴力的求解. 可以发现,若有不同的拼法,则一 ...
- 【填坑向】bzoj2038小Z的袜子 莫队
学莫队必做题,,,但是懒得写.今天来填个坑 莫队水题 莫队实际上就是按一个玄学顺序来离线计算询问,保证复杂度只会多一个n1/2,感觉是玄学(离线算法都很玄学) 易错点:要开long long(卡我半天 ...
- JavaScript-Function基础知识
function 1. 定义:一段预先设置的代码块,可以反复调用,根据输入参数的不同,返回不同的值: 2. 函数的声明方法: (1)function 命令声明函数 functio ...
- 如何对tableview进行自定义多选
前言: 很多入门不久的程序员或许都会遇到系统自带的tableview多选时cell选择时不能选择自己想要的点击时的颜色或者图片,这让初级开发者们很烦恼.今天,我试着花了几个小时的时间用了自己的想法,去 ...
- sql server 代理服务
sql server 创建维护计划失败.错误代码:c001f011. 从 IClassFactory 为 CLSID 为 {17BCA6E8-A95D-497E-B2F9-AF6AA475916F} ...