SpringBoot 中 MongoDB 的简单使用
2021/9/9 19:07:14
本文主要是介绍SpringBoot 中 MongoDB 的简单使用,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
一、SpringBoot 中 MongoDB 的简单使用
(1)pom 依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency>
(2)yml配置
spring: data: mongodb: uri: mongodb://ydt:ydtnb@123.123.123.123:27017/ydt?authSource=ydt
(3)代码
@Resource private MongoTemplate mongoTemplate; /** * 新增数据示例,jl_gps 集合没有会自动创建 */ public void testSave() { BJlGps jlGps = new BJlGps(); ... mongoTemplate.save(x, "jl_gps") } /** * 查询数据示例 */ public void testQuery() { List<TestEntity> list = new ArrayList(); Query query = new Query(); Criteria criteria = new Criteria(); String dwid = getDwid(); // 模糊查询 criteria.where("dwid").regex("^.*" + dwid + ".*$"); /* 精确查询 */ if (StringUtil.isNotEmpty(type)) { criteria.and("type").is(type); } /* 范围查询 */ if (StringUtil.isNotEmpty(sDate) && StringUtil.isNotEmpty(eDate)) { criteria.and("dt") .gte(DateUtil.strToDateLong(sDate)) .lt(DateUtil.strToDateLong(eDate)); } query.addCriteria(criteria); // 执行查询,反馈结果集 list = mongoTemplate.find(query, TestEntity.class, "test"); }
二、问题补充(问题提出者:王)
问题一:使用 MongoTemplate 查询数据第一次会比较慢
原因:第一次查询会先建立连接,导致查询慢
解决方案:在项目启动时建立连接
@Component public class MongoConnTask implements ApplicationRunner { /** * Springboot启动时,注入 MongoTemplate ,即可创建连接 */ @Resource private MongoTemplate mongoTemplate; @Override public void run(ApplicationArguments args) throws Exception { } }
问题二:可视化工具中查看时间相关数据,发现与存进去的时间少 8 小时
原因:MongoDB 存储时间为标准时间,UTC +0:00。中国标准时间为 UTC +8:00。
解决方案:无需解决
MongoTemplate 在取数据时,会自动加 8H,保证存取一致。
这篇关于SpringBoot 中 MongoDB 的简单使用的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-06-15matplotlib作图不显示3D图,怎么办?
- 2024-06-1503-Loki 日志监控
- 2024-06-1504-让LLM理解知识 -Prompt
- 2024-06-05做软件测试需要懂代码吗?
- 2024-06-0514-ShardingSphere的分布式主键实现
- 2024-06-03为什么以及如何要进行架构设计权衡?
- 2024-05-31全网首发第二弹!软考2024年5月《软件设计师》真题+解析+答案!(11-20题)
- 2024-05-31全网首发!软考2024年5月《软件设计师》真题+解析+答案!(21-30题)
- 2024-05-30【Java】百万数据excel导出功能如何实现
- 2024-05-30我们小公司,哪像华为一样,用得上IPD(集成产品开发)?