springboot集成MongoDB并在代码中实现增删改查相关语法

在项目中使用MongoDB文档数据库很频繁,存储一些非结构化数据、第三方回调数据、日志、以及一些不是那么实时需要的数据等等,当然document也可以是结构化的数据;

在职场中会有一些新入职的同事或者同为程序员的小伙伴初用MongoDB不太了解如何入手,下面就介绍一下springboot集成MongoDB并进行增删改查相关操作

1、在springboot中引入MongoDB依赖

bash 复制代码
		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-mongodb</artifactId>
            <version>2.3.4.RELEASE</version>
        </dependency>

2、配置文件配置mongo数据库连接

bash 复制代码
spring.data.mongodb.uri=mongodb://root:123456@localhost:27017/test

root:数据库账号

123456:数据库密码 搭建数据库密码尽量复杂

localhost:数据库ip,可替换具体部署服务器公网ip

27017:数据库开放端口,可映射为其它端口提高安全性

test:数据库名

3、创建Mongo实体类并映射具体集合

bash 复制代码
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.data.mongodb.core.mapping.Document;
import org.springframework.data.mongodb.core.mapping.Field;

import java.io.Serializable;

/**
 * @desc: 登录日志
 * @Author: nuoyi
 * @Date: 2023/11/13 10:47 下午
 */
@AllArgsConstructor
@NoArgsConstructor
@Data
@Builder
@Document("NuoYi_Login_Log")
public class LoginLogPo implements Serializable {
	/**
	* 主键id 自动映射到_id
	*/
	@MongoId
    private String id;
    /**
     * 用户名
     */
    @Field(value = "accountName")
    private String accountName;
    /**
     * 用户Id
     */
    @Field(value = "accountId")
    private Integer accountId;
    /**
     * 手机号
     */
    @Field(value = "mobile")
    private String mobile;

    /**
     * 登录时间
     */
    @Field(value = "loginTime")
    private String loginTime;

    /**
     * 状态码
     */
    @Field(value = "stateCode")
    private Integer stateCode;

    /**
     * 登录IP
     */
    @Field(value = "host")
    private String host;

}

4、对mongo集合进行增删改查

新增

bash 复制代码
            private final MongoTemplate mongoTemplate;


            // 构建日志对象  
            BehaviorLogPo behaviorLogPo = BehaviorLogPo.builder()
                    .requestIp(IPUtil.getIpAddr(getHttpServletRequest()))
                    .accountName(accountInfo.getName())
                    .mobile(accountInfo.getMobile())
                    .interfaceReturnResult(getResultJsonStr(result))
                    .apiDoc(apiDesc.apiMode() + " -> " + apiDesc.apiName())
                    .interfaceOperationType(apiDesc.operateType().name())
                    .requestType(httpServletRequest.getMethod())
                    .build();

            // 存到mongo里边去
            mongoTemplate.save(behaviorLogPo);

删除

bash 复制代码
			Query query1 = new Query();
            query1.addCriteria(Criteria.where("_id").is(1));
            mongoTemplate.findAndRemove(query1,BehaviorLogPo.class);

修改

bash 复制代码
						Query query1 = new Query();
                        query1.addCriteria(Criteria.where("_id").is(t.getId()));
                        Update update = new Update();
                        update.set("accountId", 1);
                        UpdateResult updateResult = mongoTemplate.updateFirst(query, update, 	BehaviorLogPo.class);

查询(分页、包含、等于、模糊、时间范围)

bash 复制代码
	    /**
	     * mongo 模糊查询正则表达式
	     */
    	private final String reg = "^.*%s.*$";

		Query query = new Query();
        // 构建分页对象
        Pageable pageable = PageRequest.of(0, 5000);
        query.addCriteria(Criteria.where("stateCode").in((Object) null));
        query.addCriteria(Criteria.where("host").is("127.0.0.1");
        query.addCriteria(Criteria.where("mobile").regex(Pattern.compile(String.format(reg, req.getUserPhone()), Pattern.CASE_INSENSITIVE)));
        String startTime = "2023-01-06 00:00:00";
        String endTime = "2023-12-06 23:59:59";

        query.addCriteria(Criteria.where("loginTime").gt(startTime).lt(endTime));
        query.with(pageable).with(Sort.by(Sort.Order.asc("loginTime")));

        List<BehaviorLogPo> dataWaitHandle = mongoTemplate.find(query, AICallInfoLog.class, "NuoYi_Login_Log");

简单的相关操作就掌握啦

springboot中使用Java代码进行MongoDB集合数据备份
docker搭建mongodb并挂载外部文件
docker内部署MongoDB授权数据库账号权限

相关推荐
缘友一世32 分钟前
macos安装mongodb
数据库·mongodb·macos
2401_857439692 小时前
Spring Boot新闻推荐系统:用户体验优化
spring boot·后端·ux
进击的女IT3 小时前
SpringBoot上传图片实现本地存储以及实现直接上传阿里云OSS
java·spring boot·后端
杨半仙儿还未成仙儿4 小时前
Spring框架:Spring Core、Spring AOP、Spring MVC、Spring Boot、Spring Cloud等组件的基本原理及使用
spring boot·spring·mvc
一 乐4 小时前
学籍管理平台|在线学籍管理平台系统|基于Springboot+VUE的在线学籍管理平台系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习
IT学长编程6 小时前
计算机毕业设计 二手图书交易系统的设计与实现 Java实战项目 附源码+文档+视频讲解
java·spring boot·毕业设计·课程设计·毕业论文·计算机毕业设计选题·二手图书交易系统
艾伦~耶格尔7 小时前
Spring Boot 三层架构开发模式入门
java·spring boot·后端·架构·三层架构
man20177 小时前
基于spring boot的篮球论坛系统
java·spring boot·后端
Java探秘者7 小时前
Maven下载、安装与环境配置详解:从零开始搭建高效Java开发环境
java·开发语言·数据库·spring boot·spring cloud·maven·idea
苹果醋38 小时前
大模型实战--FastChat一行代码实现部署和各个组件详解
java·运维·spring boot·mysql·nginx