MongoDB:简单的增删改查操作

一.概述

        本篇文章介绍在Navicat中对MongoDB数据库进行增删改查操作,在后面会介绍在Spring Boot中使用MongoTemplate对MongoDB数据库进行相关操作.如有必要可以先看看前面几篇文章.

MongoDB:MySQL,Redis,ES,MongoDB的应用场景

MongoDB:数据库初步应用

二.在Navicat进行增删改查操作

2.1 新增数据

MongoDB有以下几种方法对数据进行新增.

1) insert() 插入单个或者多个数据(文档);

2) save() 如果新新增数据主键存在那么就修改,如果不存在就新增.

3) insertOne()新增一条数据

4) insertMany()新增多条数据.

其中insertOne,insertMany与insert()的功能重复,所以这里就不多做介绍了.

2.1.1 insert()新增数据

示例代码如下:

db.user_search_record.insert({uuid:"c5e41a77a87c776c7cdbe521294ddcf6",keyword:"剪纸用品",time:ISODate(),userId:"0f6bea039ca64c9e81c7bdb43f1587ca"}
)

对照语法格式如下:

db.集合名称.insert(JSON格式的键值对
)

这里需要主要的是db不能省略,不然会提示集合(表)名称未定义.

在上面案例中ISODate()获得的是格林威治时间,需要在上面+8才能获得北京时间,时间格式时候yyyy-MM-dd HH:mm:ss 

下面代码添加多条记录,多条记录需要用 [ ] 符号,表示是一个数组.

db.user_search_record.insert([
{uuid:"c5e41a77a87c776c7cdbe521294ddcf6",keyword:"日用商品",time:ISODate(),userId:"0f6bea039ca64c9e81c7bdb43f1587ca"},
{uuid:"c5e41a77a87c776c7cdbe521294ddcf6",keyword:"食品",time:ISODate(),userId:"0f6bea039ca64c9e81c7bdb43f1587ca"},
])

在MongoDB的集合中存在_id字段,作为文档的主键,如果没有指定,会自动生成. 

2.1.2 使用save()保存文档

save()的语法格式与insert()格式类似,示例代码如下:

db.user_search_record.save({uuid:"c5e41a77a87c776c7cdbe521294ddcf6",keyword:"现切水果",time:ISODate(),userId:"0f6bea039ca64c9e81c7bdb43f1587ca"}
)

上面代码没有指定_id所以等同于insert(),将新增一条代码.如果我们指定_id,将判断_id是否存在,如果存在那么就修改原数据,如果不存在,那么新增,示例代码如下:

db.user_search_record.save({_id:ObjectId("64dc2cc9045b0000260056f5"),uuid:"c5e41a77a87c776c7cdbe521294ddcf6",keyword:"绿叶水果",time:ISODate(),userId:"0f6bea039ca64c9e81c7bdb43f1587ca"}
)

 在上面代码中需要注意_id是MongoDB特有的数据类型:ObjectId,所以需要用到ObjectId()这个方法对字符串进行转换,并且不能省略.如果上面的_id存在将对数据进行修改,如果不存在那么将新增.

 与insert()不同的是save()一次只能操作一条数据.

2.2 更新数据

        更新数据常见的方法有update(),save(),updateOne(),updateMany(),replaceOne().其中save在上面已经介绍了,

2.2.1 update()更新数据

下面代码使用update方法更新数据

db.product_detail.update(
{_id:ObjectId("64db394fd5b10c163f4ce01d")},
{$set:{title:"正宗山东烟台红富士又红又甜 顺丰包邮"}}
)

其语法格式如下:

db.product_detail.update(
{查询条件},
{$set:更新字段}
)

在上面的更新中,默认只会更新匹配到的第一条语句,如果需要更新所有匹配到的语句需要设置multi为true,这个值默认为false(不进行多条语句更新),示例如下面的代码将更新多条匹配的语句:

db.product_detail.update(
{title:"享受正宗的新疆李子美味"},
{$set:{title:"正宗的新疆李子顺丰包邮到家 皮薄美味丰富维C"}},
{multi:true}
)

2.2.2 其它更新语法介绍

         其它更新语法不常用,只做简单介绍,updateOne()只更新匹配到的第一条语句,updateMany()更新多条语句,reaplaceOne()只更新匹配到的第一条语句.

2.3 删除数据

        MongoDB中删除也有多种方法:remove(),deleteOne(),deleteMany(),最常用的是remove()方法.

2.3.1 remove()方法删除数据

remove的语法与update语法有相似之处,示例代码如下:

db.user_search_record.remove(
{_id:ObjectId("64db3bf7d5b10c163f5469d5")}, 
{justOne:true}
)

其语法格式如下:

db.集合名称.remove(
{筛选条件}, 
{可选参数}
)

在上面的代码中justOne:true表示只删除一条数据,这个值默认为false,也就是会删除所有匹配到的数据.在做删除之前最好先根据删除条件做一次查询,避免被误删.

2.3.3 其它删除方法

 deleteOne()一次删除一个文档

 deleteMany()一次删除多条匹配到的文档.

上面这两个方法都可以用remove()代替.

2.4 基本查询

任何数据库中查询是所有操作中最重要和常用的环节,我们需要从以下几个方面逐步了解

2.4.1 比较操作符

在前面的操作中,我们已经发现了mongoDB以$作为关键字的标志,这查询中也是一样.

$eq : 查询相等

$ne: 查询不相等

$gt, $gte: 查询大于,大于等于条件的文档

$lt, $lte : 查询小于, 小于等于条件的文档

$in, $nin: 查询条件必须是数组, 查询存在或者不存在这个数组里面值的文档.

2.4.2 逻辑操作符

$and : 用于多条件查询,表示并且

$or : 用于多条件查询,表示或

$nor : 用于多条件查询,表示查询文档必须不符合所有条件

$not : 只能用于一个条件查询,表示文档不符合查询条件.

2.4.3 元素操作符

$exists: 判断指定字段是否存在.

$type: 判断指定字段的数据类型

使用find()方法进行查询,案例如下:

db.product_detail.find({$and:[ 	//and中列出了三个条件必须都要满足{categoryId:{$eq:32}}, {productRating:{$gte:4.9}}, {shopId:{$not:{$eq:"4d3f317917543ab3c1ebed6300453f69"}}}],$or:[		//or列出了两个条件,必须满足其中一个{positiveReviews:{$gte:300}}, {badReviews:{$lt:10}}]}
)

find方法接受一个json数据,其中$and和$or作为数据中的两个属性,这两个属性可以接受数组作为属性值. 

2.4.4 模糊查询

在mongoDB中,模糊查询是采用的正则表达式的方式,例如下面的代码:

db.product_detail.find({$and:[{address:"深圳"},{productRating:{$gte:4.5}},{title:{$regex:"西瓜",$options:["i","x","s"]} }]}
)

$regex:"西 瓜" 是指定title字段需要模糊匹配西瓜这两个字.

$options:是设置可选参数, i表示忽略大小写,x表示忽略空格,s表示忽略换行.

三.Spring Boot 对MongoDB进行增删改查

先引用mongoTemplate

@Resource
private MongoTemplate mongoTemplate;    //mongoDB操作模板

3.1 新增文档

/*** 添加用户的收货地址* @param userAddress* @return 返回主键*/@Overridepublic String addAddress(UserAddress userAddress){//向集合中添加数据,如果没有指定_id,那么会自动生成userAddress = mongoTemplate.insert(userAddress);//返回生成的uidreturn userAddress.get_id();}

3.2 更新文档

/*** 更新用户的收货地址* @param userAddress* @return*/@Overridepublic boolean updateAddress(UserAddress userAddress){//创建查询对象Query query = new Query();//根据主键创建查询语句query.addCriteria(Criteria.where("_id").is(userAddress.get_id()));//创建更新对象Update update = new Update();//根据键值对添加更新数据update.set("address",userAddress.getAddress());update.set("province",userAddress.getProvince());update.set("tel",userAddress.getTel());update.set("city",userAddress.getCity());update.set("recipient",userAddress.getRecipient());update.set("isDefault",userAddress.getIsDefault());//将检索出来的对象进行更新UpdateResult result =  mongoTemplate.updateFirst(query,update,UserAddress.class);//判断被修改的文档数据量if(result.getModifiedCount()>0){return true;}else{return false;}}

3.3 删除文档

/*** 根据主键编号移除用户的收货地址:实际操作为将用户的收货地址的isDelete值改为true(1)* @param id* @return true:成功*/@Overridepublic boolean removeAddress(String id){//创建查询标准Query query = new Query();query.addCriteria(Criteria.where("_id").is(id));//将数据的isDeleted字段改为trueUpdate update = new Update();update.set("isDeleted",Byte.valueOf("1"));UpdateResult result = mongoTemplate.updateFirst(query,update,UserAddress.class);if(result.getModifiedCount()>0){return true;}else{return false;}}

3.4 查询文档

/*** 根据用户id查询这个用户的所有收货地址* @param uid 用户id* @return 收货地址集合*/@Overridepublic List<UserAddress> getAddressByUserId(String uid) {//创建查询对象Query query = new Query();//配置查询标准query.addCriteria(Criteria.where("userId").is(uid));List<UserAddress> list = mongoTemplate.find(query,UserAddress.class);return list;}/*** 根据主键编号查询收货地址* @param id* @return*/@Overridepublic UserAddress getAddressById(String id){//创建查询标准Query query = new Query();query.addCriteria(Criteria.where("_id").is(id));//根据主键查询值需要返回一个对象UserAddress userAddress = mongoTemplate.findOne(query,UserAddress.class);return userAddress;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/39886.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux系统服务学习(七)NFS服务、DHCP服务

文章目录 一、NFS服务概述1、任务背景2、环境准备3、NFS概述4、NFS组成5、与NFS相关的软件包6、安装NFS软件7、NFS的配置文件 二、NFS实验1、搭建NFS服务器2、编写NFS主配置文件3、启动相关的NFS服务4、搭建Web服务器5、在Web服务器中挂载NFS6、上传aws.mp4视频到NFS服务器的/s…

人工智能学习框架—飞桨Paddle人工智能

1.人工智能框架 机器学习的三要素&#xff1a;模型、学习策略、优化算法。 当我们用机器学习来解决一些模式识别任务时&#xff0c;一般的流程包含以下几个步骤&#xff1a; 1.1.浅层学习和深度学习 浅层学习(Shallow Learning)&#xff1a;不涉及特征学习&#xff0c;其特征…

Vue3 setup中使用$refs

在 Vue 3 中的 Composition API 中&#xff0c;$refs 并不直接可用于 setup 函数。这是因为 $refs 是 Vue 2 的实例属性&#xff0c;而在 Vue 3 中&#xff0c;setup 函数是与模板实例分离的&#xff0c;不再使用实例属性。 实际工作中确实有需求&#xff0c;在setup 函数使用…

迪瑞克斯拉算法

迪锐克斯拉算法 简单来说就是在有向图中&#xff0c;给定一个图中具体的出发点&#xff0c;从这个点出发能够到达的所有的点&#xff0c;每个点的最短距离是多少。到不了的点&#xff0c;距离则是正无穷。有向&#xff0c;无负权重&#xff0c;可以有环。 所以说&#xff0c;迪…

流媒体服务-传输延时(SEI插帧)

什么是延时 很多小伙伴认为&#xff0c;当推流端和拉流端显示的时间不一致&#xff0c;即为延时。 其实这种看法是比较片面的&#xff0c;不同的播放器&#xff0c;对同一路流进行测试&#xff0c;可能会得到不同的结果。 一般来说&#xff0c;延时为以下几个部分的累加组成 …

【Android】解决Lint found fatal errors while assembling a release target

报错信息&#xff1a; Android在debug模式下打包没有问题&#xff0c;但是在打包release版本时出现一下问题&#xff1a; 结果图 原因 我项目的原因是因为把正式、测试地址放到代码里了&#xff0c;忘记选中正式环境的地址&#xff0c;导致打正式包有问题&#xff1b;大家如果…

Shell编程学习之变量的使用

查看当前系统使用的命令解释器&#xff1a; linuxubuntu:~$ echo $SHELL /bin/bashshell命令&#xff1a;在终端上使用的命令&#xff0c;例如 vi a.cgcc a.c./a.outshell脚本&#xff1a;其是一个.sh文件&#xff0c;里面都是命令的集合&#xff0c;以及一些复杂的逻辑&#…

RuntimeException详解

当我们谈论Java编程中的异常处理时&#xff0c;RuntimeException是一个关键的概念&#xff0c;它在代码开发和维护中扮演着重要的角色。本文将深入探讨RuntimeException&#xff0c;了解它的特点、使用场景以及如何在代码中处理它。 什么是RuntimeException&#xff1f; 在Ja…

复合 类型

字符串和切片 切片 切片的作用是允许你引用集合中部分连续的元素序列&#xff0c;而不是引用整个集合。 例如&#xff1a; let s String::from("hello world");let hello &s[0..5]; // 切片 [0,5) 等效于&s[..5] let world &s[6..11]; // 切片…

线性动态规划入门之挖地雷

P2196 [NOIP1996 提高组] 挖地雷 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 这个题有点坑&#xff0c;就是说你只能往下挖&#xff0c;可以理解成单项路径。比如1与3之间是1代表1可以到3而3不可以到1。所以我们来思考dp把。怎么写&#xff1f;我们这么想假设1与2&#xf…

gitee上传一个本地项目到一个空仓库

gitee上传一个本地项目到一个空仓库 引入 比如&#xff0c;你现在本地下载了一个半成品的框架&#xff0c;现在想要把这个本地项目放到gitee的仓库上&#xff0c;这时就需要我们来做到把这个本地项目上传到gitee上了。 具体步骤 1. 登录码云 地址&#xff1a;https://gite…

【Pytroch】基于支持向量机算法的数据分类预测(Excel可直接替换数据)

【Pytroch】基于支持向量机算法的数据分类预测(Excel可直接替换数据) 1.模型原理2.数学公式3.文件结构4.Excel数据5.下载地址6.完整代码7.运行结果1.模型原理 支持向量机(Support Vector Machine,SVM)是一种强大的监督学习算法,用于二分类和多分类问题。它的主要思想是找…

【数据结构】树和二叉树的概念及结构

1.树概念及结构 1.1树的概念 树是一种非线性的数据结构&#xff0c;它是由n&#xff08;n>0&#xff09;个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树&#xff0c;也就是说它是根朝上&#xff0c;而叶朝下的。 有一个特殊的结点&#…

Spring Boot 中的 AOP,到底是 JDK 动态代理还是 Cglib 动态代理

大家都知道&#xff0c;AOP 底层是动态代理&#xff0c;而 Java 中的动态代理有两种实现方式&#xff1a; 基于 JDK 的动态代理 基于 Cglib 的动态代理 这两者最大的区别在于基于 JDK 的动态代理需要被代理的对象有接口&#xff0c;而基于 Cglib 的动态代理并不需要被代理对…

list

目录 迭代器 介绍 种类 本质 介绍 模拟实现 注意点 代码 迭代器 介绍 在C中&#xff0c;迭代器&#xff08;Iterators&#xff09;是一种用于遍历容器&#xff08;如数组、vector、list等&#xff09;中元素的工具 无论容器的具体实现细节如何,访问容器中的元素的方…

在ubuntu中将dict.txt导入到数据库sqlite3

将dict.txt导入到数据库 #include <head.h> #include <sqlite3.h> int do_insert(int i,char *str,sqlite3 *db); int main(int argc, const char *argv[]) {//创建泵打开一个数据库sqlite3 *db NULL;if(sqlite3_open("./my.db",&db) ! SQLITE_OK){…

【TI-CCS笔记】工程编译配置 bin文件的编译和生成 各种架构的Post-build配置汇总

【TI-CCS笔记】工程编译配置 bin文件的编译和生成 各种架构的Post-build配置汇总 TI编译器分类 在CCS按照目录下 有个名为${CG_TOOL_ROOT}的目录 其下就是当前工程的编译器 存放目录为&#xff1a; C:\ti\ccs1240\ccs\tools\compiler按类型分为五种&#xff1a; ti-cgt-arm…

2023年排行前五的大规模语言模型(LLM)

2023年排行前五的大规模语言模型(LLM) 截至2023年&#xff0c;人工智能正在风靡全球。它已经成为热门的讨论话题&#xff0c;吸引了数百万人的关注&#xff0c;不仅限于技术专家和研究人员&#xff0c;还包括来自不同背景的个人。人们对人工智能热情高涨的原因之一是其在人类多…

CS5263替代停产IT6561连接DP转HDMI音视频转换器ASL 集睿致远CS5263设计电路原理图

ASL集睿致远CS5263是一款DP1.4到HDMI2.0b转换器芯片&#xff0c;设计用于将DP1.4源连接到HDMI2.0b接收器。 CS5263功能特性&#xff1a; DP接口包括4条主通道、辅助通道和HPD信号。接收器支持每通道5.4Gbps&#xff08;HBR2&#xff09;数据速率。DP接收机结合了HDCP1.4和HDCP…

NVIDIA Omniverse与GPT-4结合生成3D内容

全球各行业对 3D 世界和虚拟环境的需求呈指数级增长。3D 工作流程是工业数字化的核心&#xff0c;开发实时模拟来测试和验证自动驾驶车辆和机器人&#xff0c;操作数字孪生来优化工业制造&#xff0c;并为科学发现铺平新的道路。 如今&#xff0c;3D 设计和世界构建仍然是高度…