mongodb新手扫盲
前言
- mongodb是什么?, 需fq
- 如何安装mongodb?
数据库基本命令
显示所有数据库:
show dbs
创建/使用数据库:
use dbName
创建数据库表,在mongoDB里又将表称为集合(collections), 因此创建表:
db.createCollection("collectionName")
显示数据库下的所有集合(表):
show tables / show collections
删除当前数据库:
db.dropDatabase()
查看当前所使用的数据库:
db.getName()
显示当前数据库的状态:
db.stats()
显示当前数据库的版本:
db.version()
注意: collection
和table
概念差不多,doc
和row
概念差不多。
集合(表)命令
增加数据
创建一个集合:
db.createCollection("tableName")
添加文档:
```
db.tableName.insert({username: "john", age: "18"})
// 或者
db.tableName.save({username: "john", age: "18"});
// 它们之间的区别
// 1. 使用save,如果对象不存在则插入,如果存在,则会调用update方法。如果是insert,或忽略调用update方法。
// 2. insert可以插入一个列表,而不用遍历,效率高。而save需要遍历,效率不如insert。
### 删除数据
1. 删除操作: `db.tableName.remove({age: 18})`
db.tableName.remove({});
### 更新数据
1. 使用update()更新
db.tableName.update({age: 18}, {$inc: {age:10}}, false ,true)
// 等价于
update tableName set age = age + 10 where age = 18;
// 关于update
db.collection.update(
// {}里的是可选的
// upsert为true表示如果记录存在就更新,不存在就插入新的记录。
// multi为true表示更新所有匹配的文档,如果为false表示只更新第一个文档(默认行为)。
2. 使用save()命令实现upsert
// 如果不指定'_id'值,save()命令会认为它是一个插入操作。
// 如果指定,就是更新。
db.calendars.save({'uid': 'yuzf', 'projectId': 'test'}); // 插入一条数据
db.calendars.save({'_id': 'test', 'uid': 'yuzf', 'projectId': 'test'}); // 更新一条数据
3. 自动更新信息
// 将name为yuzf的人的成绩加4,如果存在就更新,不存在就创建。
db.stu.update({'name': 'yuzf'}, {$inc: {grade: 4}}, {upsert: true});
// 设置字段值
db.stu.update({'name': 'yuzf'}, {$set: {'grade': 200}});
// 删除指定字段
db.stu.update({'name': 'yuzf'}, {$unset: {'grade': 200}});
4. 还有一些其他的,这里只介绍了常用的。
### 查询数据
1. 获取指定名称的集合: `db.getCollection("tableName")`
2. 获取集合里所有的数据:
db.tableName.find().pretty();
3. 获取集合里的指定数据:
db.users.find({'uid', 'yuzf'}).pretty();
4. 获取集合里的指定数据,然后指向看指定数据, 在第二个参数里添加键,并设置键的值为1即可:
db.users.find({'uid': 'yuzf'}, {'uid': 1}).pretty();
```
- 使用函数sort, limit, skip
- 以uid进行排序:
db.users.find().sort({ 'uid': 1 });
- 限制查询结果返回的最大数目为10:
db.users.find().limit(10);
- 返回查询结果除了前20条的文档的其他文档:
db.users.find().skip(20);
- 使用固定集合、自然顺序和$natural
- 固定集合必须使用
createCollection()
, 以显示的方式创建:db.createCollection("users", {capped: true, size: 20480})
- 因为固定集合的顺序和插入顺序是一样的, 如果想要逆转排序:
db.users.find().sort({ $natural: -1 }).limit(10);
获取单个文档:
db.users.findOne();
- 使用常用的聚合命令
count, distinct, group
- 统计users表里有多少个文档:
db.users.count();
- 去重:
db.users.distinct('uid');
, 将会返回一个数组,数组里包含的元素是去重了的uid
。 将结果分组:
db.calendars.group({ key: {uid: true}, initial: {total: 0}, reduce: function(items, prev) { prev.total += 1; } }); // 以uid进行分组。 // 为每个已分组的结果提供一个基数。 // 正在遍历的当前文档和聚集计数对象(我认为就是那个基数)。 // 最后的结果格式数据是: [ { 'uid': 'yuzf', 'total': 1, }, { 'uid': 'test', 'total': 3, } ]
- 使用条件操作符
- 执行大于和小于($lt,$gt,$lte,$gte)比较:
db.users.find({ departmentNumber: {$lt: 100} });
- 获取除uid为yuzf以外的其他文档:
db.calendars.find({'uid': {$ne: 'yuzf'}}).pretty();
- 指定一个匹配的数组($in):
db.calendars.find({'uid': {$in: ['yuzf', 'yangh']}}).pretty();
- 查找某个不在数组中的值:
db.calendars.find({'uid': {$nin: ['yuzf', 'yangh']}}).pretty();
- 匹配文档中的所有属性($all):
db.calendars.find({'uid': {$all: ['yuzf', 'yangh']}}).pretty();
- 在文档中搜索多个表达式:
db.calendars.find({'uid': {$or: ['yuzf, 'yangh'']}}).pretty();
- 使用slice来获取文档(分页):
不知道为什么,自己跑的时候报错,$slice unknown operator
- 还有一些其他的,感觉不是很常用。
mongoose的使用
未完待续...
参考:
mongodb新手扫盲的更多相关文章
- mongodb新手入门,mongodb命令学习
下面来总结一下mongodb新手入门的常用命令吧.要是您是mongodb新手,可以看下. 1,show dbs 查询mongodb里面的数据库列表 如果想查看当前连接在哪个数据库下面,可以直接输入db ...
- mongodb新人扫盲
前言 数据库基本命令 集合(表)命令 增加数据 删除数据 更新数据 使用update()更新 使用save()命令实现upsert 自动更新信息 查询数据 mongoose的使用 前言 mongodb ...
- MongoDB 快速扫盲贴
长话短说 经过996的历练,开发者潜意识里总是以object的视角看待事物, 现在某些数据库也具备这样的视角. MongoDB是一个文档型(类JSON 文档)数据库,相比传统的关系型row/colum ...
- Linux实战教学笔记05:远程SSH连接服务与基本排错(新手扫盲篇)
第五节 远程SSH连接服务与基本排错 标签(空格分隔):Linux实战教学笔记-陈思齐 第1章 远程连接LInux系统管理 1.1 为什么要远程连接Linux系统 在实际的工作场景中,虚拟机界面或物理 ...
- Linux新手扫盲(转载)
一. Linux特点 1.免费/开源: 2.支持多线程/多用户: 3.安全性好: 4.对内存和文件管理优越. Linux最小只需4M ——> 嵌入式开发 二. 文件目录 Linux系统所有软硬件 ...
- Linux新手扫盲
一. Linux特点 1.免费/开源: 2.支持多线程/多用户: 3.安全性好: 4.对内存和文件管理优越. Linux最小只需4M ——> 嵌入式开发 二. 文件目录 Linux系统所有软硬件 ...
- X32,X64,X86 代表什意义
X32,X64,X86是什么意思 各代表什么:X86指32位,X64指64位,现在用户最多的是XP,但win7是趋势,发展很快,建议你装个win7 32位的系统,下载的话地方很多,官方安装原版和gho ...
- Mac新手从入门到放弃MongoDB
1. 简介 MongoDB 是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案.一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最 ...
- 新手立体四子棋AI教程(1)——基础扫盲
一.引言 最近身边好几个朋友开始玩立体四子棋,激起了我的好奇心.那么首先来说什么是[立体四子棋],规则又是如何呢? 上图即为立体四子棋,规则类似于五子棋四子连在一起,但是四子棋更加多样.丰富.不仅可以 ...
随机推荐
- js精确计算
官方文档:http://mikemcl.github.io/big.js/ 使用方法: x = new Big(0.1); y = x.plus(0.2); // '0.3' var a=Big(0. ...
- 【C语言】printf()函数详解
printf函数称为格式输出函数,其关键字最末一个字母f即为"格式"(format)之意.其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上.在前面的例题中我们已多次使用过这 ...
- 裴波那序列-JAVA实现
编程输出:裴波那序列,1000项,int会越界! BigInteger [] pArr=new BigInteger [10000]; pArr[0]=new BigIntege ...
- mac jmeter 的使用
1.下载 mac下载地址:http://jmeter.apache.org/download_jmeter.cgi,下载apache-jmeter-3.1.tgz 2.下载完毕后解压,得到安装包 3. ...
- C++ fstream 详解
最近在写哈夫曼压缩,遇到了一个比较让人头疼的问题,那就是对文件的读写操作,尤其是以二进制的形式来读写,无奈C++Primer第五版上写的并不详细,很多让人困惑的地方没有涉及或者没有讲清楚.于是这几天我 ...
- kindeditor修改图片上传路径-使用webapi上传图片到图片服务器
kindeditor是一个非常好用的富文本编辑器,它的简单使用我就不再介绍了. 在这里我着重介绍一些使用kindeditor修改图片上传路径并通过webapi上传图片到图片服务器的方案. 因为我使用的 ...
- MongoDB基础教程系列--第八篇 MongoDB 副本集实现复制功能
为什么用复制 为什么要使用复制呢?如果我们的数据库只存在于一台服务器,若这台服务器宕机了,那对于我们数据将会是灾难,当然这只是其中一个原因,若数据量非常大,读写操作势必会影响数据库的性能,这时候复制就 ...
- 转账示例(三):service层面实现(线程管理Connection)(本例采用QueryRunner来执行sql语句,数据源为C3P0)
缺点:Service层面还是不应该出现关于事务的操作1.自行创建C3P0Uti,account数据库,导入Jar包 2.Dao层面 接口: package com.learning.dao; impo ...
- SSE 系列内置函数中的 shuffle 函数
SSE 系列内置函数中的 shuffle 函数 邮箱: quarrying@qq.com 博客: http://www.cnblogs.com/quarryman/ 发布时间: 2017年04月18日 ...
- [Android]Gradle 插件 DiscardFilePlugin(class注入&清空类和方法)
以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/6732128.html Android Gradle 插件 Di ...