MongoDB 学习笔记(原创)
MongoDB 学习笔记
一、数据库的基本概念及操作
| SQL术语/概念 | MongoDB术语/概念 | 解释/说明 |
|---|---|---|
| database | database | 数据库 |
| table | collection | 数据库表/集合 |
| row | document | 数据记录行/文档 |
| column | field | 数据字段/域 |
| index | index | 索引 |
| table | joins | 表连接,MongoDB不支持 |
| primary key | primary key | 主键,MongoDB自动将_id字段设置为主键 |
- 创建数据库
- > use mydb
- 查看当前连接的数据库
- > db
- -> mydb
- 查看所有的数据库
- > show dbs
- -> mydb
- 销毁数据库
- > use local
- switched to db local
- > db.dropDatabase()
二、集合(Collection)的基本操作
- 创建集合
- > db.creationCollection('users')
- 查看创建的集合
- > show collections
- 删除集合
- > db.users.drop()
- 向集合中插入数据
1.insert()
插入数据时,如果 users 集合没有创建会自动创建。
- > use mydb
- switched to db mydb
- > db.users.insert([
- ... { name : "jam",
- ... email : "jam@qq.com"
- ... },
- ... { name : "tom",
- ... email : "tom@qq.com"
- ... }
- ... ])
2.使用 save()
插入数据时,如果 users 集合没有创建会自动创建。
- > use mydb2
- switched to db mydb2
- > db.users.save([
- ... { name : "jam",
- ... email : "jam@qq.com"
- ... },
- ... { name : "tom",
- ... email : "tom@qq.com"
- ... }
- ... ])
- 更新数据
db.COLLECTION_NAME.update(SELECTION_CRITERIA,UPDATED_DATA)
- > use mydb2
- switched to db mydb2
- > db.mysb2.update({'name':'jam'},{'name':'bob'})
- 删除数据
db.COLLECTION_NAME.remove(DELECTION_CRITERIA)
- > use mydb2
- switched to db mydb2
- > db.mydb2.remove({'name':'tom'})
| 操作语句 | 作用 |
|---|---|
| db.createCollection('COLLECTION_NAME') | 创建集合 |
| db.COLLECTION.drop() | 删除集合 |
| db.COLLECTION_NAME.insert(document) | 插入文档 |
| db.COLLECTION_NAME.update(SELECTION_CRITERIA,UPDATED_DATA) | 更新文档 |
| db.COLLECTION_NAME.save({_id:ObjectId(),NEW_DATA}) | 替换已存在的文档 |
| db.COLLECTION_NAME.remove(DELECTION_CRITERIA) | 删除文档 |
三、数据查询
- find() 语句
- > use mydb
- switched to db mydb
- > db.mydb.insert({'name':'mars','age':12,'gender':'man'})
1.不加参数时返回所有记录
- > db.mydb.find()
- { "_id" : ObjectId("589dc5f3e86d38da8455b314"), "name" : "marsggbo" }
- { "_id" : ObjectId("589dcac5e86d38da8455b315"), "name" : "mars", "age" : 12, "gender" : "man" }
2.带参数
- > use mydb
- > db.mydb.find({'name':'mars'})
- { "_id" : ObjectId("589dcac5e86d38da8455b315"), "name" : "mars", "age" : 12, "gender" : "man" }
2.1 条件操作符1
(>) 大于 - $gt #greate
(<) 小于 - $lt #low
(>=) 大于等于 - $gte #equal
(<= ) 小于等于 - $lte
2.2 条件操作符2
- type
- $type
type的值:
双精度型-1
字符串-2
对象-3
数组-4
二进制数据-5
对象ID-7
布尔类型-8
数据-9
空-10
正则表达式-11
JS代码-13
符号-14
有作用域的JS代码-15
32位整型数-16
时间戳-17
64位整型数-18
Min key-255
Max key-127
范例:
- > use student
- switched to db student
- > db.student.find({"name":{$type:2}})
查找name是字符串的文档记录
- limit和skip
limit:读取指定数量的数据记录 -limit
skip:读取时跳过指定数量的数据记录
首先查看student集合中年龄大于20的数据
- > use student
- switched to db student
- > db.student.find({'age':{$gt:20}})
- { "_id" : ObjectId("589dcf6d6ac83b9ae69f63e6"), "name" : "z", "sex" : "m
- an", "age" : 23 }
- { "_id" : ObjectId("589dcf8f6ac83b9ae69f63e8"), "name" : "z", "sex" : "m
- an", "age" : 29 }
- { "_id" : ObjectId("589dd11ce3b6b824fd0620e9"), "age" : 22, "name" : "ab
- ", "sex" : "woman" }
限制只显示一个数据后,默认显示最前面的数据
(第一行命令不用重复编写,这里是因为markdown解析非得加上这句话才能高亮。。。)
- > use student
- switched to db student
- > db.student.find({'age':{$gt:20}}).limit(1)
- { "_id" : ObjectId("589dcf6d6ac83b9ae69f63e6"), "name" : "z", "sex" : "m
- an", "age" : 23 }
跳过一条数据,则可猜想显示结果为第二个数据
- > use student
- switched to db student
- > db.student.find({'age':{$gt:20}}).limit(1).skip(1)
- { "_id" : ObjectId("589dcf8f6ac83b9ae69f63e8"), "name" : "z", "sex" : "m
- an", "age" : 29 }
- pretty() 语句
作用是使查询输出的结果更美观
- > use mydb
- > db.mydb.find().pretty()
- { "_id" : ObjectId("589dc5f3e86d38da8455b314"), "name" : "marsggbo" }
- {
- "_id" : ObjectId("589dcac5e86d38da8455b315"),
- "name" : "mars",
- "age" : 12,
- "gender" : "man"
- }
- sort() 排序
与sqlite中的排序一样有升序和降序,其中升序用1表示,降序用-1表示
示例
- > use student
- switched to db student
- > db.student.find().sort({'age':1})
- { "_id" : ObjectId("589dcf866ac83b9ae69f63e7"), "name" : "z", "sex" : "f
- eman", "age" : 19 }
- { "_id" : ObjectId("589dd11ce3b6b824fd0620e9"), "age" : 22, "name" : "ab
- ", "sex" : "woman" }
- { "_id" : ObjectId("589dcf6d6ac83b9ae69f63e6"), "name" : "z", "sex" : "m
- an", "age" : 23 }
- { "_id" : ObjectId("589dcf8f6ac83b9ae69f63e8"), "name" : "z", "sex" : "m
- an", "age" : 29 }
总结:
可以使用find进行查询,sort用于排序,ensureIndex用于建立索引,aggregate用于聚合。
原文出处:marsggbo的博客
MongoDB 学习笔记(原创)的更多相关文章
- MongoDB学习笔记系列
回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助 ...
- PHP操作MongoDB学习笔记
<?php/*** PHP操作MongoDB学习笔记*///*************************//** 连接MongoDB数据库 **////*************** ...
- mongoDB 学习笔记纯干货(mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)
最后更新时间:2017-07-13 11:10:49 原始文章链接:http://www.lovebxm.com/2017/07/13/mongodb_primer/ MongoDB - 简介 官网: ...
- MongoDB学习笔记(转)
MongoDB学习笔记(一) MongoDB介绍及安装MongoDB学习笔记(二) 通过samus驱动实现基本数据操作MongoDB学习笔记(三) 在MVC模式下通过Jqgrid表格操作MongoDB ...
- 【转】MongoDB学习笔记(查询)
原文地址 MongoDB学习笔记(查询) 基本查询: 构造查询数据. > db.test.findOne() { "_id" : ObjectId("4fd58ec ...
- MongoDB学习笔记(六)--复制集+sharding分片 && 总结
复制集+sharding分片 背景 主机 IP 服务及端口 Server A ...
- MongoDB学习笔记(五)--复制集 && sharding分片
主从复制 主从节点开启 主节 ...
- MongoDB学习笔记(四)--索引 && 性能优化
索引 基础索引 ...
- MongoDB学习笔记(三)--权限 && 导出导入备份恢复 && fsync和锁
权限 绑定内网I ...
随机推荐
- Tooltip浮动提示框效果(掌握里面的小知识)
使用原生JavaScript设计和实现Tooltip浮动提示框特效,了解代码简化.事件绑定.事件冒泡等技巧和知识. 特效四个关键点:显示:鼠标移到ToolTip超链接上时,ToolTip提示框可以显示 ...
- php 引入文件 include 和require
php 如何引用文件? 先建一个php 文件,php文件名要和所建的类名相同, 然后直接在php 中用include("")/include"" 和requir ...
- 反汇编看c++引用
继续反汇编系列,本次使用vc2008在x86体系下分析c++中的引用. 定义一个引用类型和将一个变量转换成引用类型一样吗? 引用比指针安全,真的是这样吗,对引用不理解的话比指针还危险. 为什么要用常量 ...
- Laravel / Lumen 框架修改 创建时间 和 更新时间 对应字段
为避免浪费时间--先上解决方案 在Model中重写 CREATED_AT 和 UPDATED_AT 两个类常量就可以了,这两个常量分别是创建时间和更新时间的字段名. ================= ...
- Java之路——名词解释(一)
一.开篇 许多人在初接触Java的时候,都会被各种Java的英文缩写名词给弄得头晕脑胀.看一个技术,内容里又会有一堆其他的技术名词,看了半天不知所云.尝试去查一下这些名词的解释,除了非常学术性的解释之 ...
- Ant学习总结3(很多的属性,用的时候方便查找)
感谢原作者:http://blog.csdn.net/lipeijs3/article/details/5137160 一. Ant 与 Makefile : GNU Mak ...
- esri-leaflet入门教程(5)- 动态要素加载
esri-leaflet入门教程(5)- 动态要素加载 by 李远祥 在上一章节中已经说明了esr-leaflet是如何加载ArcGIS Server提供的各种服务,这些都是服务本身来决定的,API脚 ...
- 从0移植uboot (二) _启动流程分析
经过了上一篇的配置,我们已经执行make就可以编译出一个uboot.bin,但这还不够,首先,此时的uboot并不符合三星芯片对bootloader的格式要求,其次,此时的uboot.bin也没有结合 ...
- Kosaraju算法解析: 求解图的强连通分量
Kosaraju算法解析: 求解图的强连通分量 欢迎探讨,如有错误敬请指正 如需转载,请注明出处 http://www.cnblogs.com/nullzx/ 1. 定义 连通分量:在无向图中,即为连 ...
- 【译】Nodejs最好的ORM - TypeORM
TypeORM github: https://github.com/typeorm/typeorm 这篇译文是从TypeORM github上的使用说明上翻译过来的,已经提交PR并merge到库中了 ...