5-MongoDB实战演练

简介: 本文介绍某头条文章评论功能的需求分析与技术实现,涵盖基于MongoDB的增删改查、按文章ID查询评论、评论点赞等功能,采用SpringDataMongoDB与MongoTemplate优化操作,并完成实体类设计及分页查询实现。

5.1 需求分析
某头条的文章评论业务如下:

早晨空腹喝水,是对还是错?

外从小喝凉水,冰水,也没见伤亡率就试我大天朝高多少?喝热水喝开水是当年我国建国初期

不少人认为,早起喝杯水,能够起到补水乃至减肥的作用.

生条件差,水不烧开了喝细菌多容易致病,而习惯性传下来喝开水而己,并不是什么别的原因

我们不应该把清晨浪费在手机上,健康很重要,杯温水幸福你我他

研究表明,刚烧开的水干万不能喝,因为烫嘴

我夏天空膜喝凉开水,冬天喝温开水

中间一条线两边是饭店17天前

我一直喝凉开水,冬天夏天都喝

厚德载物4426998517天有

|惊鸿照影|17天前

工人日报2019-08-0508:41:50

河畔半守护为伊人17天前

[捂脸[捂脸]岁月不饶人

专家说不能空腹吃饭

64条评论

FENGBETTA17天前

回复,5条回复V

你还年轻,火力旺.

回复收起回复人

TEAWEB17天前

南街村夫17天前

南街村夫17天前

写下您的评论..

查看更多评平论

12凸口

4仓回

4仓口

6凸回

8E

回复

回复

回复

评平论

回复

回复

2凸口

06

3F


需要实现以下功能:
1)基本增删改查API
2)根据文章id查询评论
3)评论点赞
5.2 表结构分析
数据库:articledb

:不可见;1:可见;

如果为0表示文章的顶级评论

评论的日期时间

MONGO的主键的字段

OBJECTLDSTRING

段名称

CREATEDATETIME

字段类型

评论人ID

字段含义

IKENUM

栏兰文章评论

ARTICLEID

点赞数

评论人呢称

COMMENT

REPYNUM

文章ID

STRING

ARENTIC

ICKNAME

NT32

备注

评论内容

ONTENT

回复数

上级ID

SERID

STRING

STRING

STATE

TRING

状态

INT32

STRING

STRING

DATE

1D

ID


5.3 技术选型
5.3.1 mongodb-driver(了解)
mongodb-driver是mongo官方推出的java连接mongoDB的驱动包,相当于JDBC驱动。我们通过一个入门的案例来了解mongodb-driver的基本使用。
官方驱动说明和下载:链接 ,官方驱动示例文档:链接
5.3.2 SpringDataMongoDB
SpringData家族成员之一,用于操作MongoDB的持久层框架,封装了底层的mongodb-driver。
官网主页: https://projects.spring.io/spring-data-mongodb/
5.4 文章微服务模块搭建
(1)搭建项目工程article,pom.xml引入依赖:
(2)创建application.yml
(3)创建启动类
cn.itcast.article.ArticleApplication
(4)启动项目,看是否能正常启动,控制台没有错误。
5.5 文章评论实体类的编写
创建实体类 创建包cn.itcast.article,包下建包po用于存放实体类,创建实体类
cn.itcast.article.po.Comment
说明:
索引可以大大提升查询效率,一般在查询字段上添加索引,索引的添加可以通过Mongo的命令来添加,也可以在Java的实体类中通过注解添加。
1)单字段索引注解@Indexed
org.springframework.data.mongodb.core.index.Indexed.class
声明该字段需要索引,建索引可以大大的提高查询效率。
Mongo命令参考:

db.comment.createIndex({"userid":1})

2)复合索引注解@CompoundIndex
org.springframework.data.mongodb.core.index.CompoundIndex.class
复合索引的声明,建复合索引可以有效地提高多字段的查询效率。
Mongo命令参考:

db.comment.createIndex({"userid":1,"nickname":-1})

5.6 文章评论的基本增删改查
(1)创建数据访问接口 cn.itcast.article包下创建dao包,包下创建接口
cn.itcast.article.dao.CommentRepository
(2)创建业务逻辑类 cn.itcast.article包下创建service包,包下创建类
cn.itcast.article.service.CommentService
(3)新建Junit测试类,测试保存和查询所有:
cn.itcast.article.service.CommentServiceTest
添加结果:

CLASS:CN.ITCAST.ARTICLE.PO.COMMENT

CREATEDATETIME:2019-08-3103:23:40.921

ID:*1167639062832615424

CONTENT:"则试式添的好居

KNAME:凯大帝

ARTIC1EID:"1OEEOE

USERID:"1EE3

REPLYNUM:E

1IKENUM:E

STATE:1


5.7 根据上级ID查询文章评论的分页列表
(1)CommentRepository新增方法定义
(2)CommentService新增方法
(3)junit测试用例:
cn.itcast.article.service.CommentServiceTest
(4)测试
使用compass快速插入一条测试数据,数据的内容是对3号评论内容进行评论。

ARTLCLEDB.COMMENT

专家说不能空腹吃饭,响健康."

5D689257EDFC962DA8DD895E

"我一直喝凉开水,冬天夏天喝."

TICLEID:"100E81

INSERTDOCUMENT

INSERTDOCUMENT

NICKNAME:凯散..

CONTENT:你年全,.

NICKNAMESTRIR

OCUMENTSO

USERID:1OE3

建康.""1003"

DOCUMENTS

伊人焦摔"

AGGRES

PARENTID:3

CANCEL

STRING

IDMIXED

OFILTER

INSERT

COMMENT

STRING

STRING

"100001"

STRING

凯撒大帝"

100001"

杰克船长

号.""1004"

ROSE"

三LS

ID:"33"

STRING

STRING

3

2"


执行测试,结果:

----总记录数:1
----当前页数据:[Comment{id='33', content='你年轻,火力大', publishtime=null, userid='1003', nickname='凯撒大帝', createdatetime=null, likenum=null, replynum=null, state='null', parentid='3', articleid='100001'}]

5.8 MongoTemplate实现评论点赞
我们看一下以下点赞的临时示例代码: CommentService 新增updateThumbup方法
以上方法虽然实现起来比较简单,但是执行效率并不高,因为我只需要将点赞数加1就可以了,没必要查询出所有字段修改后再更新所有字段。我们可以使用MongoTemplate类来实现对某列的操作。
(1)修改CommentService

Java

运行代码复制代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

//注入MongoTemplate

@Autowired

private MongoTemplate mongoTemplate;


/**

* 点赞数+1

* @param id

*/

public void updateCommentLikenum(String id){

//查询对象

Query query=Query.query(Criteria.where("_id").is(id));

//更新对象

Update update=new Update();

//局部更新,相当于$set

// update.set(key,value)

//递增$inc

// update.inc("likenum",1);

update.inc("likenum");

//参数1:查询对象

//参数2:更新对象

//参数3:集合的名字或实体类的类型Comment.class

mongoTemplate.updateFirst(query,update,"comment");

}

(2)测试用例:
cn.itcast.article.service.CommentServiceTest

Java

运行代码复制代码

1

2

3

4

5

6

7

8

/**

* 点赞数+1

*/

@Test

public void testUpdateCommentLikenum(){

//对3号文档的点赞数+1

commentService.updateCommentLikenum("3");

}

执行测试用例后,发现点赞数+1了:

CONTENT:"我一直喝凉开水,冬天粤天喝.

CREATEDATETIME:2019-08-0601:

ICKNAME:"杰克船长"

ARTIC1EID:"1EOE81

USERID:1EE4

1:05:06.321

1IKENUM:667

STATE:

ID:M3"


相关文章
|
2月前
|
NoSQL Linux Shell
2-MongoDB单机部署
本文详细介绍MongoDB在Windows和Linux系统下的安装、配置与启动方法,包括下载地址、版本选择、命令行及配置文件启动方式,Shell连接、图形化工具Compass的使用,并附有常见问题解决与安装包资源。
95 1
 2-MongoDB单机部署
|
2月前
|
Java 数据库
[舍弃,后续需调整][Blog]JPA实现分页需求(☆☆)
新人已搭建本地环境,今日任务为改造博客网站的查询功能,实现分页显示。可基于三层架构修改或使用提供的基础工程,并在数据库中添加足够数据以展示分页效果,参考示例图与代码压缩包完成开发。
36 1
[舍弃,后续需调整][Blog]JPA实现分页需求(☆☆)
|
2月前
|
存储 缓存 算法
零拷贝
实现文件传输时,传统方式因频繁系统调用导致大量上下文切换与内存拷贝,性能低下。零拷贝技术通过减少用户态与内核态切换、避免重复数据拷贝,显著提升效率。结合PageCache预读与缓存优势,适用于小文件高并发场景;而大文件传输则推荐异步IO加直接IO,绕过PageCache,避免缓存污染,兼顾性能与资源利用。
85 1
|
安全 数据建模 网络安全
什么是泛域名证书
什么是泛域名证书
3240 0
|
网络安全 数据安全/隐私保护 Docker
GitLab安装使用
GitLab安装使用
683 0
GitLab安装使用
|
23天前
|
人工智能 数据可视化 物联网
《显卡 4090 就能跑!小白也能炼出私有大模型》
大模型微调是AI落地的关键技术,通过定向训练让通用模型在特定领域“从会到精”。本文详解微调原理、LoRA/QLoRA等高效方法,并提供评估与实操建议,助力新手快速上手,实现低成本、高精度的模型定制。
327 4
|
5月前
|
开发者 Python
Python神技:用列表推导式让你的代码更优雅
Python神技:用列表推导式让你的代码更优雅
539 99
|
存储 内存技术
内存条RAM详细指南
内存条(RAM)是电脑中用于临时存储数据和程序的部件,CPU依赖它执行操作。内存条经历了从主内存扩展到读写内存整体的发展,常见类型包括SDRAM和DDR SDRAM。内存容量、存取时间和奇偶校验是衡量其性能的关键指标。在选购时,应考虑类型、容量、速度和品牌,知名品牌的内存条提供更好的可靠性和稳定性。
5522 2
|
11月前
|
虚拟化 Windows
Hyper-V无声音问题排查指南,是什么原因导致的
Hyper-V无声音问题可能由多种原因导致,如虚拟机配置、增强会话模式、远程桌面连接、集成服务及物理机音频驱动等。需逐一排查:确保操作系统和音频驱动正确安装,启用增强会话模式,检查RDP设置,更新集成服务和物理机驱动,查看日志并重启相关服务。通过这些步骤,通常可以解决大多数无声音问题。若问题依旧,建议联系技术支持。
|
数据采集 存储 监控
一站式数据采集存储的利器:阿里云InfluxDB®️数据采集服务
阿里云InfluxDB®除了提供稳定可靠的时序数据库服务,还提供了非常便捷的数据采集服务。用户能够方便查看各个采集源的运行状态并管理它们,采集的数据会自动存储到阿里云InfluxDB®。用户无需担心运维的问题,实现数据从采集到分析的一站式服务。
2978 0