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

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

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

1、在springboot中引入MongoDB依赖

		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-mongodb</artifactId>
            <version>2.3.4.RELEASE</version>
        </dependency>

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

spring.data.mongodb.uri=mongodb://root:123456@localhost:27017/test

root:数据库账号
123456:数据库密码 搭建数据库密码尽量复杂
localhost:数据库ip,可替换具体部署服务器公网ip
27017:数据库开放端口,可映射为其它端口提高安全性
test:数据库名

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


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集合进行增删改查

新增

            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);

删除

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

修改

						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);

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

	    /**
	     * 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授权数据库账号权限

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

oNuoyi

你的鼓励将是我创作的做大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值