java - 使用 spring-data-jpa 保存新条目
问题描述
我有一个带有一些默认列值的 MySQL 表和 RestController。当我 POST 到 /orders 端点时,我发送一个 JSON 对象,我得到一个响应,其中包含我发送的信息 + MySQL 条目的自动生成的 ID。
我该怎么做才能使请求返回已保存在数据库中的完整条目,包括默认列值?我知道,我在响应中获得的 ID,我可以使用它发出 GET 请求以检索所有数据,但我不想发出新请求。
MySQL 订单表
`ID` int NOT NULL AUTO_INCREMENT,
`order_date` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
`delivery_date` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
订单模型
@Entity
@Table(name="orders")
@Getter @Setter @DynamicUpdate @DynamicInsert
public class OrderModel {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="ID")
private Integer id;
@Temporal(TemporalType.TIMESTAMP)
@Column(name="order_date")
Date orderDate;
@Temporal(TemporalType.TIMESTAMP)
@Column(name="delivery_date")
Date deliveryDate;
protected OrderModel() {}
}
弹簧休息控制器
@RestController
@AllArgsConstructor
@RequestMapping("orders")
public class OrdersController {
private final OrdersRepository ordersRepo;
@ResponseBody
@PostMapping
public OrderModel addOrder(@RequestBody OrderModel order) {
return ordersRepo.saveAndFlush(order);
}
}
POST 请求正文:
{}
POST 响应正文:
{
"id":40,
"orderDate":null,
"deliveryDate":null
}
解决方案
一种可能的解决方案是,仅在您需要的地方使用 EntityManager 的refresh(Object entity)方法,用于您要保存在数据库中的实体并将其取回。
另一种解决方案是在存储库基类中使用相同的refresh(Object entity)方法以使其成为全局而不更改任何其他内容,如下所示:
- 创建一个新的自定义存储库基类,它会覆盖save方法。(包括刷新(对象实体))
- 让 spring-boot 知道您希望它使用您刚刚创建的自定义存储库基类。
- 现在,当您调用存储库的 save() 方法时,它将使用您在存储库基类中创建的方法。
public class CustomBaseRepository<T, ID> extends SimpleJpaRepository<T, ID> {
private final EntityManager entityManager;
private final JpaEntityInformation<T, ?> entityInformation;
CustomBaseRepository(JpaEntityInformation<T, ?> entityInformation, EntityManager entityManager) {
super(entityInformation, entityManager);
this.entityManager = entityManager;
this.entityInformation = entityInformation;
}
@Transactional
@Override
public <S extends T> S save(S entity) {
if (entityInformation.isNew(entity)) {
entityManager.persist(entity);
//the next line of code saves the entry in the database for real and updates the entity object with the new information
entityManager.refresh(entity);
return entity;
} else {
return entityManager.merge(entity);
}
}
}
@SpringBootApplication
@EnableJpaRepositories(repositoryBaseClass = CustomBaseRepository.class)
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
推荐阅读
- powershell - 如果行包含来自变量 A OR B 的值,则从文件中排除
- html - 自定义复选框,无 Javascript,不更改 HTML,仅 CSS
- php - 获取 Icecat API 以获取产品信息
- jenkins - Jenkins 和 gradle - 使用最新版本的 CI 依赖项构建项目,用于生产的特定版本
- python - 将python变量插入prosgresql查询
- file - SSL - SecurityContext - 未处理的异常:FileSystemException:无法打开文件 - 错误:没有这样的文件或目录,errno = 2
- c# - 使用存储库时 where 条件生成不带过滤器的 sql
- python - 如何在 Ubuntu 14.04 (Mint 17) 上升级 numpy 版本
- string - 使用 gnuplot 将字符串绘制到表格中
- python - 使用过滤器通过查询设置表单字段的值