我认为您的代码存在问题,如果我正确理解了您的输入,便是您在中传递了逗号(,)分隔的日期字符串
LocalDate.parse(abc.getDate(),dateTimeFormatter)。
您每次都需要传递一个日期到parse()方法,因为它试图使用日期格式器格式格式化提供的字符串输入,因此当在“
03/03/2020”的输入中遇到逗号(,)时发生错误, 03/03/2020”。
请参考官方文档。
您可以尝试以下操作:
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(PK),abc_id(ABC表的FK参考),日期(此处存储单个日期)。现在,假设上表的名称是abc_date_map,然后在您的ABC实体中将该实体称为OneToMany。像下面一样
@Entityclass 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实体将像
@Entitypublic class AbcDateMap{ @Column(name="abc_id") private Integer abcId; @Column(name="date") private LocalDate localDate; // getters setters}您的实体插入逻辑将类似于:
public Long insert(ABC abc) { abc.setNo(); List<AbcDateMap> l = new ArrayList<>(); AbcDateMap abcDate = new AbcDateMap(); for (String date : abc.getDate().split(",")) { abcDate.setLocalDate(); abcDate.setAbcId(abc.getId()); } abc.setAbcDateMapEntityList(l); repo.save(abc);}现在,上面的代码不是确切的代码,您将不得不对其进行完善,可能会出现语法/语义错误。另外,您将需要根据需要进行更改。
希望对您有帮助。
祝你好运,学习愉快!



