How to shorten names of query methods in Spring Da

2020-02-08 05:25发布

Consider a Spring Data Jpa Repository:

public interface UserRepository extends JpaRepository<User, Long> {

    User findOneByDeletedIsFalseAndActivationKey(String activationKey);

    List<User> findAllByDeletedIsFalseAndActivatedIsFalseAndCreatedDateBefore(DateTime dateTime);

    User findOneByDeletedIsFalseAndLogin(String login);

    User findOneByDeletedIsFalseAndEmail(String email);

}

Notice each method has "DeletedIsFalse" in it. Is there a simple way to make method names shorter? Like i.e.:

@FullMethodName("findOneByDeletedIsFalseAndEmail")
User findOneByEmail(String email);

2条回答
爱情/是我丢掉的垃圾
2楼-- · 2020-02-08 05:57

Use default Java 8 feature for wrapping, just like so:

// use findOneByEmail instead
User findOneByDeletedIsFalseAndEmail(String email);

default User findOneByEmail(String email) {
    return findOneByDeletedIsFalseAndEmail(email);
}

See an example.

查看更多
Fickle 薄情
3楼-- · 2020-02-08 06:00

Now you can use Java 8 default interface methods as @Maksim Kostromin described. But there is no such a feature in Spring.

-- Old answer

There is no such a way. You can specify any name for a method and add an annotation @Query with parameter value which holds desired query to database like this:

@Query(value="select u from User u where u.deleted=false and u.email=:email")
User findOneByEmail(@Param("email")String email);

or, with native sql query:

@Query(value="SELECT * FROM users WHERE deleted=false AND email=?1", nativeQuery=true)
User findOneByEmail(String email);

You can also use names that follow the naming convention for queries since @Query annotation will take precedence over query from method name.

@Query docs

Upd:

from Spring docs:

Although getting a query derived from the method name is quite convenient, one might face the situation in which ... the method name would get unnecessarily ugly. So you can either use JPA named queries through a naming convention ... or rather annotate your query method with @Query.

查看更多
登录 后发表回答