- • Quickstart
- • Documentation
- • Documentation DevOps
- • Next Steps
- • Spring Boot
- • Spring Data
- › Spring Data MongoDB
- • Spring Security
- • Frontend
- • Multi-Module
Last updated: 2022-03-20
CreatedDate and LastModifiedDate in Spring Data MongoDB
It is often of interest to add the date of creation and last modification to a document. Spring Data MongoDB provides excellent support for this by enabling auditing.
First, we need to extend the config of our Spring Boot application. While for relational databases
@EnableJpaAuditing is available, for Spring Data MongoDB we use the annotation
@PreUpdate is not available for MongoDB - auditing is the best option we have here.
Extending our configuration for auditing
By specifying the
DateTimeProvider we can also use
OffsetDateTime as a field type. Otherwise only
java.util.Date as well as joda time types would be available. Details about the converters can be found in this article. With this configuration in place, we can now enable
@LastModifiedDate on our documents.
We also need a
@Version field in our documents, otherwise there will be problems in combination with the Id field. If the id is pre-filled by our application, auditing assumes that the document already existed in the database and
@CreatedDate is not set. With the version field however, the life cycle of our entity is correctly captured.
In Bootify's Free plan you can opt for adding dateCreated and lastUpdated fields for all your entities in the database settings. It will enabled auditing and provide a
DateTimeProvider to support
OffsetDateTime as a field type.