SpringData MongoDB学习总结

2023-10-16 07:36

本文主要是介绍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()
:计算匹配文档的数量。

这篇关于SpringData MongoDB学习总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/220025

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

二分最大匹配总结

HDU 2444  黑白染色 ,二分图判定 const int maxn = 208 ;vector<int> g[maxn] ;int n ;bool vis[maxn] ;int match[maxn] ;;int color[maxn] ;int setcolor(int u , int c){color[u] = c ;for(vector<int>::iter