mongodb增删改查常用命令总结
前言
去年我还折腾过mongodb,后来用不到也就没碰了,这就导致了我忘的一干二净,不得不感叹,编程这东西只要不用,就会忘没了。现在我想重拾mongodb,来总结一下常用命令,主要就是增删改查。
另外,关于mongodb数据的安装配置,我就不赘述了,推荐我之前写过的两篇博客:
接下来,我直奔主题咯~
新建数据库
创建之前,我们看看当前有哪些数据库,使用:
show dbs
接下来创建一个新的数据库:
// 使用这个数据库,没有则会创建
use test // 此时还没有创建成功,只有在其中创建一个集合时,这个新数据库才会创建成功
db.user.insert({"name":"wj","age":}) // 上面命令在test数据库里新建了一个user集合,并插入了数据,此时再执行show dbs ,已经有了test数据库
插入(增加)数据
前面已经提及了,格式如下:
db.集合名.insert({"name":"wj"})
注意在使用这条命令前,要切换到对应数据库,比如:
use test
这样新增的集合就在这个数据库下,可以使用命令:
show collections
来查看当前数据库下有哪些集合
删除
1. 删除当前数据库
db.dropDatabase()
2. 删除集合
db.集合名.drop()
3. 删除数据
db.集合名.remove(条件) // 比如要删除user集合下name为wj的数据,则
db.user.remove({"name":"wj"})
修改
修改前要按条件查找的,例如我要把名为小明的同学的年龄修改为3岁,那么命令如下:
db.user.update({"name":"小明"}, {$set:{"age":}}) // 上面命令的格式
db.集合名.update({条件}, {$set:{修改的值}})
注意花括号不要写错,另外加上$set
是修改,如果不加的话,就是后面的替换前面的,如:
// 修改前
{ "name":"小明"} // 修改
db.user.update({"name":"小明"},{"age":}) // 修改后
{ "age":}
默认情况下,只会修改满足条件的第一条数据,如果希望修改所有满足条件的数据,加上{multi:true}
,如:
db.user.update({"sex":"男"}, {$set:{"age":}}, {multi:true})
查找
关于查询的方式就比较多啦。敲命令时,多注意符号的书写。
1. 查询集合下所有数据
db.user.find() //user是集合名
2. 查询 age == 20 的数据
db.user.find({"age":})
3. 查询 age > 20 的数据 (大于)
db.user.find({"age":{$gt:}})
4. 查询 age < 20 的数据 (小于)
db.user.find({"age":{$lt:}})
5. 查询 age >= 30 的数据 (大于或等于)
db.user.find({"age":{$gte:}})
6. 查询 age <= 30 的数据 (小于或等于)
db.user.find({"age":{$lte:}})
7. 查询 age >= 20 并且 age <= 30 的数据 (且)
db.user.find({"age":{$gte:,$lte:}})
8. 查询 name 中包含 wj 的数据
db.user.find({"name":/wj/})
9. 查询 name 中以 w 开头的数据
db.user.find({"name":/^w/})
10. 查询指定列的数据
// 只查看name列
db.user.find({},{"name":}) // 只查看age列
db.user.find({},{"age":}) // 只查看name和age列
db.user.find({},{"name":,"age":})
11. 查询指定列的数据,带条件(age > 20)
db.user.find({"age":{$gt:}},{"name":,"age":})
12. 排序
// 按照年龄来排序 db.user.find().sort({"age":}) // 升序 db.user.find().sort({"age":-}) // 降序
13. 多条件查询
db.user.find({"name":"wj","age":}) // 应该好理解,查询同时满足这两个条件的数据,前面忘记说了
14. 查询前三条数据
db.user.find().limit()
15. 查询五条之后的数据
db.user.find().skip() // 好理解,跳过前5条,显示的就是五条之后的数据
16. 查询 5-10 之间的数据
db.user.find().skip().limit()
17. 或 查询
db.user.find({$or:[{"age":},{"age":}]})
18.查询第一条数据
db.user.findOne() //这样也可以哦
db.user.find().limit()
总结
建议上面每条命令都自己试试,如果不成功,注意符号的书写是否正确,尤其是花括号。当然很可能是我手滑写错了,希望知道的人给我指出哦,谢谢。
mongodb增删改查常用命令总结的更多相关文章
- HBase数据库增删改查常用命令操作
最近测试用到了Hbase数据库,新建一个学生表,对表进行增删改查操作,把常用命令贴出来分享给大家~ 官方API:https://hbase.apache.org/book.html#quickstar ...
- Mysql数据库基础增删改查常用语句命令
Mysql增删改查常用语句命令 一.增删改查语句总览 创建: create(创建数据库) 增:insert(插入表数据) 删:drop.delete(删除表.删除表数据) 改:update.alter ...
- 数据库——MongoDB增删改查
MongoDB增删改查操作 本文包含对数据库.集合以及文档的基本增删改查操作 数据库操作 #1.增 use config #如果数据库不存在,则创建并切换到该数据库,存在则直接切换到指定数据库. #2 ...
- MongoDB - 增删改查及聚合操作
目录 MongoDB - 增删改查及聚合操作 一. 数据库操作(database) 1. 创建及查看库 2. 删除库 二. 集合collectionc=操作(相当于SQL数据库中的表table) 1. ...
- MySQL增删改查常用语句命令
增删改查语句增删改查的语句命令为 增:insert删:delete改:update查:SELECT或者show 库操作创建数据库:create database shujukuba;创建带字符集的数据 ...
- MongoDB增删改查表文档
MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写,是一个基于分布式文件存储的开源数据库系统.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关 ...
- mongodb增删改查操作
Note:mongodb存储的是文档,且文档是json格式的对象,所以增删改查都必须是json格式对象. 注:mongodb常用库和表操作,但mongodb在插入数据时,不需要先创建表. show d ...
- [MongoDB]增删改查
摘要 上篇文章学习了mongodb在windows上的安装,以及如何开启mongodb,最后列举了简单的增删改查操作.本篇将继续深入学习一下增删改查. 相关文章 [MongoDB]入门操作 CRUD ...
- springMVC操作mongoDB增删改查
下面是mongoDb简单的增删改查(新闻类) 附:query.addCriteria(Criteria.where("modelId").ne("").ne(n ...
随机推荐
- Java枚举类的7种常用的方法
转载于:https://www.cnblogs.com/xhlwjy/p/11314368.html
- 2018 焦作网络赛 L Poor God Water ( AC自动机构造矩阵、BM求线性递推、手动构造矩阵、矩阵快速幂 )
题目链接 题意 : 实际上可以转化一下题意 要求求出用三个不同元素的字符集例如 { 'A' .'B' .'C' } 构造出长度为 n 且不包含 AAA.BBB CCC.ACB BCA.CAC CBC ...
- Python3 获取一大段文本之间两个关键字之间的内容
用re或者string.find.以下是re代码 123456789101112131415import re#文本所在TXT文件file = '123.txt' #关键字1,2(修改引号间的内容)w ...
- 深入理解二阶段提交协议(DDB对XA悬挂事务的处理分析)(一)
https://sq.163yun.com/blog/article/165554812476866560
- uswgi
1.安装uwsgi注意: 1)在系统环境安装,非虚拟环境 2)使用对应python版本安装 3)要先安装python开发包 ###sudo apt-get install python3.6-dev ...
- webpack3升级webpack4
cnpm i webpck@4 webpack-cli -D cnpm i webpack-cli -D cnpm update npm WARN deprecated extract-text-we ...
- 用node批量压缩html页面
最近在写一个用了layui的后台管理系统.因为某些原因,html,css,js都写在.html里,并且没有用到别的打包工具.所以写了一个用node命令批量压缩页面并且混淆js的小工具.node安装ht ...
- Java缓存技术有哪些
我们用ehcache在本地,分布式用redis和memcache,各有各的好处,现在企业都是应用很多种中间件供俺们码农选择.
- Eclipse Setting
下载 https://www.eclipse.org/downloads/packages/ 自动保存代码 编码设置 代码自动提示 .abcdefghijklmnopqrstuvwxyz 字体大小设置 ...
- php设计模式-注册树模式
php注册树模式 1.什么是注册树模式? 注册树模式通过将对象实例注册到全局对象树上,需要的时候将对象从全局对象树上取下来,就像小时候买糖葫芦一样,卖糖葫芦的将糖葫芦插在一个大的杆子上,人们买的时候就 ...