MongoDB增删改
一、数据库操作
显示现有的数据库,命令:show dbs 或者 databases;
示当前使用的数据库,命令:db
切换当前使用的数据库,命令:use 数据库名称
删除数据库,命令:db.dropDatabase()
二、Collection 操作
显示现有的集合,命令:show collections 或者 tables;
插入并保存文档 insert方法,可以单独插入一个文档,也可以插入多个,用“[ ]”即可,每个Doc必须小于16MB
db.user.insert({"user_id":"u1","score":});
删除文档 remove,只是删除文档,集合还在;如果使用 drop命令,会连带集合和索引都删掉
db.user.remove({"user_id":"u1"});
db.user.drop();
文档替换,命令: db.集合名称. update(条件,新的文档);
db.collection.update(
<query>,
<update>,
{
upsert: <boolean>,
multi: <boolean>,
writeConcern: <document>
}
)
参数说明:
query : update的查询条件,类似sql update查询内where后面的。
update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
writeConcern :可选,抛出异常的级别。
$set :指定一个字段的值,如果字段不存在,会创建一个
db.user.update({"user_id":"u1"},{$set:{"name":"name1"}});
$unset :删掉某个字段
db.user.update({"user_id":"u1"},{$unset:"name"});
$inc : 用来增加已有键的值,如果字段不存在,会创建一个。只能用于整型、长整型、或双精度浮点型的值
db.user.update({"user_id":"u1"},{$inc:{"score":5}});
$push:向已有数组的末尾加入一个元素,要是没有就新建一个数组
db.user.update({"user_id":"u1"},{$push:{"xueke":"hx"}});
$each:通过一次$push来操作多个值
db.user.update({"user_id":"u1"},{$push:{"xueke":{$each:["yy","gs"]}}});
$slice:限制数组只包含最后加入的n个元素,其值必须是负整数
db.user.update({"user_id":"u1"},{$push:{"xueke":{$each:["yy","gs"],$slice:-2}}}

$sort:对数组中的元素,按照指定的字段来对数据进行排序(1为升序,-1为降序),然后再按照slice删除。

db.user.update({"user_id":"u1"},{$push:{"xueke":{$each:["yy","yw","sx"],$slice:-4,$sort:-1}}});

注意:不能只将$slice或者$sort与$push配合使用,且必须使用$each
$ne:判断一个值是否在数组中,如果不在则添加进去
db.user.update({"user_id":"u1","xueke":{$ne:"xd"}},{$push:{"xueke":"xd"}});
$addToSet:将数组作为数据集使用,以保证数组内的元素不会重复
db.user.update({"user_id":"u1"},{$addToSet:{"xueke":"english"}});
$pop :从数组一端删除元素,{$pop:{key:1}},从末尾删掉一个,-1则从头部删除
db.user.update({"user_id":"u1"},{$pop:{"xueke":}});
$pull:按照条件来删除所有匹配的元素
db.user.update({"user_id":"u1"},{$pull:{"xueke":"yy"}});
12:$:用来修改第一个匹配的元素
db.user.update({"user_id":"u1"},{$set:{"xueke.1":"yy"}});
save方法:如果文档存在就更新,不存在就新建,主要根据”_id”来判断
db.user.save({"_id":"ObjectId("5b5862e4ac45f21aabc51432")","user_id":"u2","name":"n2"});
MongoDB增删改的更多相关文章
- 数据库——MongoDB增删改查
MongoDB增删改查操作 本文包含对数据库.集合以及文档的基本增删改查操作 数据库操作 #1.增 use config #如果数据库不存在,则创建并切换到该数据库,存在则直接切换到指定数据库. #2 ...
- MongoDB - 增删改查及聚合操作
目录 MongoDB - 增删改查及聚合操作 一. 数据库操作(database) 1. 创建及查看库 2. 删除库 二. 集合collectionc=操作(相当于SQL数据库中的表table) 1. ...
- [MongoDB]增删改查
摘要 上篇文章学习了mongodb在windows上的安装,以及如何开启mongodb,最后列举了简单的增删改查操作.本篇将继续深入学习一下增删改查. 相关文章 [MongoDB]入门操作 CRUD ...
- springMVC操作mongoDB增删改查
下面是mongoDb简单的增删改查(新闻类) 附:query.addCriteria(Criteria.where("modelId").ne("").ne(n ...
- 第二部分 Mongodb增删改查
学习内容:1.mongodb增加操作2.mongodb删除操作3.mongodb查询操作增删改查的高级应用Capped Collection(固定集合)GridFS 大文件上传或下载 1: inser ...
- MongoDB(六)java操作mongodb增删改查
java操作mysql数据库的代码我们已经了如指掌了.增删改查,java对mongodb数据库也是类似的操作,先是数据库连接.再是进行操作. 首先我们进入进入admin数据库.然后建立自己的数据库te ...
- MongoDB增删改查表文档
MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写,是一个基于分布式文件存储的开源数据库系统.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关 ...
- mongodb增删改查操作
Note:mongodb存储的是文档,且文档是json格式的对象,所以增删改查都必须是json格式对象. 注:mongodb常用库和表操作,但mongodb在插入数据时,不需要先创建表. show d ...
- mongodb增删改查常用命令总结
前言 去年我还折腾过mongodb,后来用不到也就没碰了,这就导致了我忘的一干二净,不得不感叹,编程这东西只要不用,就会忘没了.现在我想重拾mongodb,来总结一下常用命令,主要就是增删改查. 另外 ...
- Python对MongoDB增删改查
pip install pymongo import pymongo # 建立连接 client = pymongo.MongoClient() # 指定数据库 (不存在则会新建) db = clie ...
随机推荐
- Java项目开发
项目开发整体构建: MVC+DAO设计模式 用面向对象的方式理解和使用数据库,一个数据库对应一个java项目 数据库--项目 表--类 字段--属性 表中的一条数据--类的一个对象 M:模型层 Jav ...
- Oracle sql 复习题目总结
sql 题目一 表结构 1.表名:g_cardapply 字段(字段名/类型/长度): apply_no varchar8; //申请单号(关键字) apply_date date; //申请日期 s ...
- mysql使用慢查询日志分析数据执行情况
#查询慢查询日志文件路径show variables like '%slow_query%';#开启慢查询日志 ; #设置慢查询阀值为0,将所有的语句都记入慢查询日志 ;#未使用索引的查询也被记录到慢 ...
- 当前主流的小型嵌入式 GUI
当前主流的嵌入式 GUI当前主流的小型嵌入式 GUI 主要有:emWin(uCGUI),TouchGFX,Embedded Wizard GUI,uGFX 和 MicroChip GUI. 当然,还有 ...
- Windows 自动定时执行任务的方法
windows 自动定时执行任务的几种实现方法 Task Schedul Windows自动定时执行任务,常见的方法有三种: Windows 任务计划程序 Windows Service SQL ...
- Benchmark result without MONITOR running: Benchmark result with MONITOR running (redis-cli monitor > /dev/null): 吞吐量 下降约1半 Redis监控工具,命令和调优
https://redis.io/commands/monitor In this particular case, running a single MONITOR client can reduc ...
- nodejs做中间层,转发请求
简述node中间层的优势 node中间层,可以解决前端的跨域问题,因为服务器端的请求是不涉及跨域的,跨域是浏览器的同源策略导致的,关于跨域可以查看跨域复习使用node坐中间层,方便前后端分离,后端只需 ...
- python 设计模式之策略模式
这几天太忙了,都没空写,所以持续了好几天. 1.策略模式的定义: 策略模式定义了算法族,分别封装起来,让他们之间可以互相替换,此模式让算法的变化独立于使用算法的客户. 通俗的讲,也就是将那些使用的方法 ...
- OpenSL ES: OpenSL ES 简介
1. OpenSL ES 是什么 OpenSL ES (Open Sound Library for Embedded Systems)是无授权费.跨平台.针对嵌入式系统精心优化的硬件音频加速API. ...
- webdriver报不可见元素异常方法总结
最近一直在学Selenium相关东西,学到webdriver这块,出现报不可见元素异常方法异常,后来网上找了好多相关资料都没搞定,也没看明白,最后发现是xpath中写了calss属性有问题.现在把学习 ...