java.time.format.DateTimeParseException:无法解析文本'03 / 03 / 2020,03 / 03/2020',未分析的文本位于索引10

时间:2020-04-27 07:52:17

标签: java spring-boot spring-data-jpa

我有一个包含“否”和“日期”的表格。这将是动态形式。在Spring Boot JPA中进行批处理更新时,我得到了“ java.time.format.DateTimeParseException:无法解析文本'03 / 03 / 2020,03 / 03/2020',在索引10处发现了未解析的文本”

@RequestMapping(value="/abcpage", produces = { MediaType.APPLICATION_JSON_VALUE })
public String savePurchaseEntries(@ModelAttribute ABC abc,HttpSession session)
{

    System.out.println(abc);
    DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("dd/MM/yyyy");
    LocalDate today = LocalDate.parse(abc.getDate(),dateTimeFormatter);
    abc.setLoclaDate(today);
    return "redirect:/home";
}

这里ABC是实体类,我可以以dd / mm / yyyy格式获取日期值,并将其转换为localdate并设置为实体。

ABC[NO=101,102,date=03/03/2020,03/03/2020]

对于一个条目,它工作正常,但在批量处理时会抛出异常。

@Entity
class ABC{ 
@column(name="NO") 
private String NO;
@Transient
private String date;
@Column(name="invdate")
private LocalDate loclaDate;
//getters & setters//tostring
}

1 个答案:

答案 0 :(得分:0)

我认为您的代码存在问题,如果我正确理解了您的输入,则是您在LocalDate.parse(abc.getDate(),dateTimeFormatter)中传递了逗号分隔的日期字符串。

您每次需要将一个日期传递给parse()方法,因为它试图使用日期格式器格式来格式化提供的字符串输入,因此在输入“ 03/03”时遇到逗号(,)时会发生错误/ 2020,03 / 03/2020”。

请参阅official documentation for same.

您可以尝试以下操作:

String[] inputDates = abc.getDate().split[","];
for (String date : inputDates) {
 // you can now use LocalDate.parse(abc.getDate(),dateTimeFormatter) here
 // write your logic here.
}

我希望这可以帮助您消除疑问,如果不让我知道您的确切问题,我会尽力帮助您。

编辑1 用于插入数据

下面是一种插入数据的方法,

创建一个表,该表将存储具有3列的日期-id(P.K。),abc_id(ABC表的F.K. ref。),日期(此处存储单个日期)。 现在,假设上表的名称为abc_date_map,然后在您的ABC实体中将该实体称为OneToMany。如下所示,

@Entity
class ABC { 

 @Column(name="NO") 
 private String NO;

 @Transient
 private String date;

 @Column(name="abc_date_map_id")
 private List<AbcDateMap> abcDateMapEntityList;

 //getters & setters//tostring

}

您的AbcDateMap实体就像

@Entity
public class AbcDateMap{

 @Column(name="abc_id")
 private Integer abcId;

 @Column(name="date")
 private LocalDate localDate;

 // getters setters

}

您的实体插入逻辑将类似于:

public Long insert(ABC abc) {

 abc.setNo(/*something*/);

 List<AbcDateMap> l = new ArrayList<>();

 AbcDateMap abcDate = new AbcDateMap();
 for (String date : abc.getDate().split(",")) {
  abcDate.setLocalDate(/*parse date here and store*/);
  abcDate.setAbcId(abc.getId());
 }
 abc.setAbcDateMapEntityList(l);
 repo.save(abc);

}

现在,上面的代码不是确切的代码,您必须对其进行完善,可能会出现语法/语义错误。另外,您还需要根据需要进行更改。

希望这对您有所帮助。

祝你好运,学习愉快!