SpringData MongoDB学习总结

目录

一、简介

二、搭建

三、操作

(1)、集合操作

(2)、文档操作

相关注解

POJO

添加文档

查询文档

更新文档

删除文档

聚合操作


一、简介

NoSql数据库

键值对key-value 存储redis用户缓存,用户信息回话,配置信息,购物车
文档存储数据结构不严格,表结构可变类json MongoDB
列族存储
图形存储   

优势:

基于灵活的json文档模型,非常适合敏捷方式的快速开发,临时增加字段影响很小

其实与生俱来的高可用,高水平扩展能力

应用场景

游戏场景用户的装备信息,积分等
物流场景订单信息-状态
社交场景用户信息,地理位置索引,附件的人,地点等信息
视频直播用户数据,礼物信息等
大数据应用云存储系统

二、搭建

docker安装mongoDB

docker pull mongo1、创建mongo数据持久化目录mkdir -p /docker_volume/mongodb/data
运行容器
docker run -itd --name mongo -v /docker_volume/mongodb/data:/data/db -p 27017:27017 mongo 
进入容器
docker exec -it mongo /bin/mongosh // 创建用户
use admindb.createUser({user: "root",pwd: "123456",roles: [ { role: "root", db: "admin" } ]}
)

三、操作

配置文件

spring:data:mongodb:host: ip地址 #ipport: 27017     #端口号 username: root #用户password: 123456 #密码database: admin  #数据库名字--集合名字

数据库结构:

数据库(admin,test)--集合--文档

(1)、集合操作

相当于mysql中的数据库

 // 判断是否有这个集合boolean has =mongoTemplate.collectionExists("emp");// 删除集合mongoTemplate.dropCollection("emp");// 创建集合mongoTemplate.createCollection("emp");

例如:

@Autowired
MongoTemplate mongoTemplate;
@Test
void test1(){// 判断是否有这个集合    boolean has = mongoTemplate.collectionExists("emp");    if(has){// 删除集合        mongoTemplate.dropCollection("emp");    }// 创建集合    mongoTemplate.createCollection("emp");}

(2)、文档操作

相当于mysql中的表操作

数据操作

相关注解

@Document作用在类上,表示当前文档@Document(文档名称,集合名称)
@Id作用在字段上映射id字段
@Field作用在字段上映射字段
@Transient该字段不会保存到数据库中

POJO

@AllArgsConstructor
@NoArgsConstructor
@Document("emp")
@Data
public class Employee {@Id    private Integer id;    @Field    private String name;    @Field    private int age;    @Field    private Double salary;    @Field    private Date birthday;}

添加文档

1、单条数据Employee zs=  new Employee(1,"张三",21,500.00,new Date());
// 添加文档  id存在时候更新数据--用于添加或者修改mongoTemplate.save(zs);
mongoTemplate.save(zs); // 用于添加或者修改,支持批量插入
// 如果 id存在会报错
mongoTemplate.insert(zs); // 用于添加2、批量添加
@Test
void  insert(){List<Employee>list= Arrays.asList(new Employee(21,"往往",21,500.00,new Date()),        new Employee(31,"小王",21,500.00,new Date()),        new Employee(41,"小张",21,500.00,new Date()),        new Employee(51,"肖红梅",21,500.00,new Date()));    // 批量插入,如果id存在,会抛出异常--用于添加    mongoTemplate.insert(list, Employee.class);}

查询文档

1、查询全部
List<Employee> all = mongoTemplate.findAll(Employee.class);2、根据id查询
Employee empTem = mongoTemplate.findById(1, Employee.class);3、查询一条
Employee one = mongoTemplate.findOne(new Query(), Employee.class);log.info("one:{}",one);4、条件查询
@Test
public void tes3(){// 查询 id>=20 且 id<= 的字段    List<Employee> list = mongoTemplate.find(Query.query(Criteria.where("id").gte(20).lte(60)), Employee.class);    log.info("id>20的数据:{}",list);}5、模糊查询/正则查询正则不需要有 / /  List<Employee> list = mongoTemplate.find(Query.query(Criteria.where("name").regex("张")), Employee.class);6、多条件查询
@Test
public void tes5(){Criteria criteria=new Criteria();   // criteria.orOperator()    //  条件查询  name 为张三  id 为2    criteria.andOperator(Criteria.where("name").is("张三"),Criteria.where("id").is(2));    List<Employee> list = mongoTemplate.find(Query.query(criteria), Employee.class);    log.info("的数据:{}",list);}
7、排序//asc 升序,decs降序List<Employee> list = mongoTemplate.find(new Query().with(Sort.by(Sort.Order.desc("id"))), Employee.class);
8、分页使用skip和limt配合p = (pageNumber - 1) * pageSizeq = pageSizeskip(p) // 跳过p条数据limt(q) // list最大保留q条数据
例如:
// 分页查询
@Test
public void tes7(){int pageName=3;    int pageSize=4;    int p=(pageName-1)*pageSize;    int q=pageSize;    List<Employee> list = mongoTemplate.find(new Query().skip(p).limit(q), Employee.class);    log.info("第三页数据:{}",list);
}8、json字符串查询
@Test
public void tes8(){String json="{name:'张三'}";  Query query=new BasicQuery(json);    List<Employee> list = mongoTemplate.find(query, Employee.class);    log.info("json串查询:{}",list);}

更新文档

数据修改

1、更新一条
// 把id=1的 的行中 name改成小帅,更新查询到的第一条
mongoTemplate.updateFirst(Query.query(Criteria.where("id").is(1)), Update.update("name","小帅"), Employee.class);2、更新--没有找到目标就进行添加操作
mongoTemplate.upsert(Query.query(Criteria.where("id").is(202)), Update.update("name", "小帅").set("salary",100), Employee.class);或者
mongoTemplate.save(new Employee(202,"往往",21,500.00,new Date(),"新字段"));3、批量更新
public void testUpdate2(){// 批量更新    UpdateResult result = mongoTemplate.updateMulti(Query.query(Criteria.where("name").is("张三")), Update.update("name", "小红"), Employee.class);    log.info("生效条数:{}",result.getModifiedCount());}UpdateResult 对象getMatchedCount() 返回满足查询条件的文档数。getModifiedCount() 返回实际更新的文档数。wasAcknowledged() 返回更新操作是否被服务器确认。

删除文档

删除数据

   1、 删除所有文档mongoTemplate.remove(new Query(), Employee.class);   2、删除指定的mongoTemplate.remove(Query.query(Criteria.where("id").is(1)), Employee.class);

聚合操作

处理数据的计算结果(诸如统计平均值,求和等)

聚合管道

类似stream流

可以用mongoTemplate.find().stream() 代替

match(Criteria criteria)
:根据指定的查询条件筛选文档。可以使用Criteria对象来定义查询条件。
project(String... fieldNames)
:选择要包含在结果中的字段。可以指定字段名或使用表达式进行投影操作。
group(String... fieldNames)
:按照指定的字段对文档进行分组。可以使用表达式或函数来定义分组操作。
sort(Sort sort)
:对结果进行排序。可以根据指定的字段进行升序或降序排序。
skip(long num)
:跳过指定数量的文档。
limit(long num)
:限制结果集的大小。
unwind(String fieldName)
:将一个数组字段展开为多个文档,并保持其他字段的一致性。
lookup(String from, String localField, String foreignField, String as)
:执行左连接操作,将当前集合与指定的外部集合进行关联。
replaceRoot(String fieldName)
:将指定字段的值作为新文档的根级别。
count()
:计算匹配文档的数量。

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

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

相关文章

【深度学习 | Transformer】释放注意力的力量:探索深度学习中的 变形金刚,一文带你读通各个模块 —— Positional Encoding(一)

&#x1f935;‍♂️ 个人主页: AI_magician &#x1f4e1;主页地址&#xff1a; 作者简介&#xff1a;CSDN内容合伙人&#xff0c;全栈领域优质创作者。 &#x1f468;‍&#x1f4bb;景愿&#xff1a;旨在于能和更多的热爱计算机的伙伴一起成长&#xff01;&#xff01;&…

kettle应用-从数据库抽取数据到excel

本文介绍使用kettle从postgresql数据库中抽取数据到excel中。 首先&#xff0c;启动kettle 如果kettle部署在windows系统&#xff0c;双击运行spoon.bat或者在命令行运行spoon.bat 如果kettle部署在linux系统&#xff0c;需要执行如下命令启动 chmod x spoon.sh nohup ./sp…

C#控制台程序读取输入按键非阻塞方式

参考内容&#xff1a; http://www.dutton.me.uk/2009-02-24/non-blocking-keyboard-input-in-c/ 相关代码&#xff1a; while (true) {if (Console.KeyAvailable){ConsoleKeyInfo key Console.ReadKey(true);switch (key.Key){case ConsoleKey.F1:Console.WriteLine("Y…

【计算机网络笔记】分组交换 vs 电路交换

系列文章目录 什么是计算机网络&#xff1f; 什么是网络协议&#xff1f; 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 系列文章目录 以一个具体的场景为例&#xff1a;N个用户共享这个1M bps链路。假设每一个用户活动时需要的链路带宽是100kb/s&#…

视频监控系统/安防视频平台EasyCVR广场视频细节优化

安防视频监控系统/视频云存储/安防监控EasyCVR视频汇聚平台基于云边端智能协同&#xff0c;支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。安防视频汇聚平台EasyCVR拓展性强&#xff0c;视频能力丰富&#xff0c;可实现视频监控直播、视频轮播、…

Maven 使用教程(二)

一、如何创建JAR并将其安装在本地存储库中&#xff1f; 制作JAR文件非常简单&#xff0c;可以通过执行以下命令来完成&#xff1a; mvn package现在可以查看${project.basedir}/target目录&#xff0c;您将看到生成的JAR文件。 现在&#xff0c;您需要将生成的工件&#xff0…

华为9.20笔试 复现

第一题 丢失报文的位置 思路&#xff1a;从数组最小索引开始遍历 #include <iostream> #include <vector> using namespace std; // 求最小索引值 int getMinIdx(vector<int> &arr) {int minidx 0;for (int i 0; i < arr.size(); i){if (arr[i] …

spring boot Rabbit高级教程

消息可靠性 生产者重试机制 首先第一种情况&#xff0c;就是生产者发送消息时&#xff0c;出现了网络故障&#xff0c;导致与MQ的连接中断。 为了解决这个问题&#xff0c;SpringAMQP提供的消息发送时的重试机制。即&#xff1a;当RabbitTemplate与MQ连接超时后&#xff0c;…

【git】500 Whoops, something went wrong on our end.

在访问公的的git 时出现了500错误提示. 500 Whoops, something went wrong on our end. 哎呀&#xff0c;我们这边出了问题。 TMD 出了什么问题了&#xff1f;&#xff1f;&#xff1f;一脸懵逼。 登录git 服务器。 查看git的状态。 命令&#xff1a; gitlab-ctl statu…

互联网Java工程师面试题·Java 总结篇·第一弹

目录 1、面向对象的特征有哪些方面&#xff1f; 2、访问修饰符 public,private,protected,以及不写&#xff08;默认&#xff09;时的区别&#xff1f; 3、String 是最基本的数据类型吗&#xff1f; 4、float f3.4;是否正确&#xff1f; 5、short s1 1; s1 s1 1;有错吗…

华为OD机考算法题:开心消消乐

题目部分 题目开心消消乐难度易题目说明给定一个 N 行 M 列的二维矩阵&#xff0c;矩阵中每个位置的数字取值为 0 或 1&#xff0c;矩阵示例如&#xff1a; 1 1 0 0 0 0 0 1 0 0 1 1 1 1 1 1 现需要将矩阵中所有的 1 进行反转为 0&#xff0c;规则如下&#xff1a; 1) 当点击一…

java中char类型和byte类型的区别?

在Java中&#xff0c;char 类型和 byte 类型是两种不同的数据类型&#xff0c;以下是它们之间的主要区别&#xff1a; 表示范围&#xff1a;char 类型用于表示Unicode字符&#xff0c;它可以表示从U0000到UFFFF之间的字符。而 byte 类型是一个8位的有符号整数&#xff0c;可以表…

基于Spring Boot开发的汽车租赁管理系统

文章目录 项目介绍主要功能截图:后台前台部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于Spring Boot开发的汽车租赁…

动态规划算法(3)--0-1背包、石子合并、数字三角形

目录 一、0-1背包 1、概述 2、暴力枚举法 3、动态规划 二、石子合并问题 1、概述 2、动态规划 3、环形石子怎么办&#xff1f; 三、数字三角形问题 1、概述 2、递归 3、线性规划 四、租用游艇问题 一、0-1背包 1、概述 0-1背包&#xff1a;给定多种物品和一个固定…

ChatGPT,AIGC 数据库应用 Mysql 常见优化30例

使用ChatGPT,AIGC总结出Mysql的常见优化30例。 1. 建立合适的索引:在Mysql中,索引是重要的优化手段,可以提高查询效率。确保表的索引充分利用,可以减少查询所需的时间。如:create index idx_name on table_name(column_name); 2. 避免使用select * :尽可能指定要返回的…

HTML笔记

注释标签&#xff1a;<!-- --> 标题标签&#xff1a;&#xff08;作用范围依次递减&#xff09; <h1></h1> <h2></h2> <h3></h3> <h4></h4> <h5></h5> <h6></h6> 段落标签&#xff1a;<p&g…

抖音开放平台第三方代小程序开发,授权事件、消息与事件通知总结

大家好&#xff0c;我是小悟 关于抖音开放平台第三方代小程序开发的两个事件接收推送通知&#xff0c;是开放平台代小程序实现业务的重要功能。 授权事件推送和消息与事件推送类型都以Event的值判断。 授权事件推送通知 授权事件推送包括&#xff1a;推送票据、授权成功、授…

03-spring启动流程细节

文章目录 1.构造器调用2.initPropertySources()方法扩展3.customizeBeanFactory 定制BeanFactory4.loadBeanDefinitions(beanFactory) 1.构造器调用 注意子类调用父类构造器和子类调用子类其他构造器 2.initPropertySources()方法扩展 AbstractApplicationContext#initPrope…

智能油烟机 优化烹饪体验

如果说空调是夏天最伟大的发明&#xff0c;那么油烟机则是健康厨房的伟大推进者。随着科技的发展&#xff0c;智能化的油烟机逐渐走进了人们的日常生活。每当我们在爆炒、油炸食物的时候&#xff0c;油烟总能呛得人眼睛痛、鼻子难受&#xff0c;传统的油烟机面前我们还需要手动…

vue3后台管理框架之路由配置

pnpm install vue-router 在src新建文件夹views和router 1.1基本 路由配置 :hash 路由模式 // 对外配置路由 import Login from @/views/login/index.vue import Home from @/views/home/index.vue import Error from @/views/404/index.vue export cons