需求:
hibernate,原有数据直接新加int字段,并且使用到该条数据时再赋值(123456789...),不同的模板对应都是12345...按顺序排
遇到问题:
只用set方法改变数据属性时,临时能改变对象对应该字段的信息,切能正确返回给前台,但是数据库中该字段信息还是程序中设置新添字段时的默认值。
解决办法:
spring data jpa的 xxxrepository.save(object);方法支持修改部分属性后直接保存该对象;代码如下
private static List<ReportResource> sortDoc(List<ReportResource> list, String templateId) {
List<ReportResource> collect = new ArrayList<ReportResource>();
//静态注入
ReportResourceRepository reportResourceRepository = SpringUtil.getBean(ReportResourceRepository.class);
//位置字段新加的,为了不删除原报告数据,先对原数据位置字段进行赋值
for (int i = 0; i < list.size() ; i++ ) {
if(list.get(i).getDocPosition() == 0){
list.get(i).setDocPosition(i + 1);
reportResourceRepository.save(list.get(i));
//reportServiceNewImpl.saveReportResource(sids, userId, groupName, chapter, img_data, secondaryChapter, reportType, templateId, imgType, chapterPosition, reportId)
}
}
collect = list.stream().sorted(Comparator.comparing(ReportResource::getDocPosition)).collect(Collectors.toList());
return collect;
}
期间参考学习了相关对象存储的几个状态的博客,但最终还是自己的实践给出最后的答案。