Is it possible to create read-only repositories using Spring Data?
I have some entities linked to views and some child entities for which I would like to provide a repository with some methods like findAll()
, findOne()
and some methods with the @Query
annotation. I would like to avoid providing methods like save(…)
and delete(…)
since they make no sense and could create errors.
public interface ContactRepository extends JpaRepository<ContactModel, Integer>, JpaSpecificationExecutor<ContactModel> {
List<ContactModel> findContactByAddress_CityModel_Id(Integer cityId);
List<ContactModel> findContactByAddress_CityModel_Region_Id(Integer regionId);
// ... methods using @Query
// no need to save/flush/delete
}
Thanks!
Yes, the way to go is to add a handcrafted base repository. You usually use something like this:
public interface ReadOnlyRepository<T, ID extends Serializable> extends Repository<T, ID> {
T findOne(ID id);
Iterable<T> findAll();
}
You can now have you concrete repos extend that just defined one:
public interface PersonRepository extends ReadOnlyRepository<Person, Long> {
T findByEmailAddress(String emailAddress);
}
The crucial part defining the base repo is that the method declarations carry the very same signature as the methods declared in CrudRepository
if that's the case we can still route the calls into the implementation bean backing the repository proxy. I've written a more detailed blog post about that topic in the SpringSource blog.