Skip to content

Improve strategy for persisting referenced entities [DATAJDBC-210] #437

Open
@spring-projects-issues

Description

@spring-projects-issues

This is an Epic gathering various approaches to improve the writing behaviour of Spring Data JDBC.

If we have an Aggregate Root A referencing entities B on update the following SQL statements get executed:

  • delete all previously referenced Bs
  • update A
  • insert all now referenced Bs

We should improve this in multiple ways:

  1. Use upserts on Bs and only delete those not longer present
  2. Use batched statements for inserts (and updates) This is implemented.
  3. Allow detection of changed Bs. There are various possibilities how to do this
    • have an annotated attribute carrying this information
    • wrap everything in proxies to track this (I really don't like this because I think it's opening a can of worms)
    • one way or the other compare with the version currently in the database. Not sure how to do that, possibly with a JDBC specific API

Also, performancetests would be nice and probably a good first step.

Create separate issues to work on any of these. Use this issue to discuss these and other strategies to improve persisting performance.

Jens Schauder opened this ticket as DATAJDBC-210

Metadata

Metadata

Assignees

Labels

Type

No type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions