springboot+mongodb+jpa使用save()方法保存数据后id为0

针对Spring Boot升级后,使用JPA保存数据时ID为0的问题,本文介绍了一种通过修改监听器实现自增ID的解决方案。

最近做mongodb版本升级,springboot版本从1.4.0.RELEASE升级到1.5.10.RELEASE后出现jpa使用save()方法保存数据后id为0的问题。

解决:

以下为原代码,使用监听器,继承 AbstractMongoEventListener ,重写其中的onBeforeConvert方法来处理自增功能

public void onBeforeConvert(final Object source) {
		if (source != null) {
			ReflectionUtils.doWithFields(source.getClass(), new ReflectionUtils.FieldCallback() {
				@Override
				public void doWith(java.lang.reflect.Field paramField) throws IllegalAccessException {
					ReflectionUtils.makeAccessible(paramField);
					if (paramField.isAnnotationPresent(GeneratedValue.class)) {
						paramField.set(source, getNextId(source.getClass().getSimpleName()));
					}
				}
			});
		}
	}

将原代码onBeforeConvert方法修改如下:

@Override
	public void onBeforeConvert(BeforeConvertEvent<Object> event) {
		if (event != null) {
			Object source = event.getSource();
			if (source != null) {
				ReflectionUtils.doWithFields(source.getClass(), new ReflectionUtils.FieldCallback() {
					@Override
					public void doWith(java.lang.reflect.Field paramField) throws IllegalAccessException {
						ReflectionUtils.makeAccessible(paramField);
						if (paramField.isAnnotationPresent(GeneratedValue.class)) {
							paramField.set(source, getNextId(source.getClass().getSimpleName()));
						}
					}
				});
			}
		}
	}

原因:

查看源码后发现AbstractMongoEventListener类中的onBeforeConvert(E source)方法已弃用,新的是onBeforeConvert(BeforeConvertEvent<E> event)

在这里插入图片描述

### Spring Boot 整合 MySQL 和 MongoDB 示例教程 #### 项目依赖设置 为了使 Spring Boot 应用程序能够连接到 MySQL 和 MongoDB 数据库,在 `pom.xml` 文件中需引入必要的依赖项。 对于 MySQL: ```xml <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency> <!-- MyBatis 或者 JPA --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.4</version> </dependency> ``` 针对 MongoDB,则应加入如下依赖[^3]: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-mongodb</artifactId> </dependency> ``` #### 配置文件调整 在 `application.properties` 中定义两个数据库的具体参数,如主机名、端口、用户名密码等信息。这里给出一个基本的例子来说明如何配置这两个同的数据源[^2]。 ```properties # MySQL Configuration spring.datasource.mysql.url=jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC spring.datasource.mysql.username=root spring.datasource.mysql.password=password spring.datasource.mysql.driver-class-name=com.mysql.cj.jdbc.Driver # MongoDB Configuration spring.data.mongodb.uri=mongodb://localhost:27017/mydb ``` #### 实体映射与仓库接口创建 当涉及到关系型数据库(MySQL),通常会使用 ORM 工具比如 Hibernate 来简化对象持久化过程;而对于 NoSQL 类型的文档存储系统(MongoDB),则可以利用 Spring Data 提供的支持来进行更便捷的操作[^1]。 ##### 关系型数据库 (MySQL) 假设有一个名为 User 的表结构,那么对应的实体类可能是这样的形式: ```java @Entity @Table(name = "users") public class User { @Id private Long id; private String name; // getters and setters... } ``` 接着为该模型建立 Repository 接口以便执行 CRUD 操作: ```java @Repository public interface UserRepository extends JpaRepository<User, Long> {} ``` ##### 文档型数据库 (MongoDB) 同样地,如果存在一个集合叫做 Product ,其关联的对象应该像这样设计: ```java @Document(collection="products") public class Product { @Id private String id; private String title; private double price; // standard constructors / methods omitted for brevity } ``` 再为其编写相应的 Repository : ```java public interface ProductRepository extends MongoRepository<Product, String> {} ``` #### 控制器层实现业务逻辑调用 最后一步是在控制器里注入上述提到的数据访问组件,并通过 RESTful API 向外部暴露功能点。下面展示了一个简单的例子用于新用户记录至 MySQL 表内以及查询商品列表来自 MongoDB 集合。 ```java @RestController @RequestMapping("/api/v1") public class MainController { @Autowired private UserRepository userRepository; @Autowired private ProductRepository productRepository; @PostMapping("/addUser") public ResponseEntity<String> addUser(@RequestBody User user){ try{ userRepository.save(user); return new ResponseEntity<>("User added successfully", HttpStatus.CREATED); }catch(Exception e){ return new ResponseEntity<>(e.getMessage(),HttpStatus.INTERNAL_SERVER_ERROR); } } @GetMapping("/getProducts") public List<Product> getProducts(){ return productRepository.findAll(); } } ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值