== Spring Data JDBC basics === SimpleEntityTests This example demonstrate basic usage of JDBC based repositories. * The `SimpleEntityTests` demonstrate CRUD operations for an entity without references, just simple properties of various types. * The `CategoryContext` shows how to configure an application context so that Spring Data JDBC can create repositories. * The `ApplicationListener` registered in `CategoryContext` demonstrate how to react to events published by Spring Data JDBC and how entities can get manipulated in such event listeners. === AggregateTests This example demonstrates various ways to bend what the standard mapping of Spring Data JDBC can do. * `AggregateConfiguration.idSetting()` registers an `ApplicationListener` to implement a custom id generation strategy for `LegoSet` and `Manual`. * `AggregateConfiguration.namingStrategy()` registers a custom `NamingStrategy` in order to map property and class names to database columns and tables. * The `minimumAge` and `maximumAge` properties show a way to use types which don't have direct mapping to a SQL type, by marking them with `@Transient` and having converted properties for Spring Data JDBC to use. * The `models` attribute demonstrate mapping of a `Map<simple type, entity>`. It does work out of the box, but in this case the the key of the map should be one attribute of the entity. This is achieved by providing a custom `NamingStrategy` which maps both to the same database column. * When the database returns a data type for query which Spring Data JDBC doesn't map out of the box a custom conversion can be registered using a `ConversionCustomizer` as demonstrated in `AggregateContext.conversionCustomizer()`. * `LegoSetRepository` has methods that utilize `@Query` annotations. * Note that `Model` is a value class, i.e. it is immutable, and doesn't have an ID.