hibernate存储库中的自定义方法

时间:2014-04-14 21:18:23

标签: spring hibernate repository

我想为hibernate CrudRepository添加自定义方法。我正在使用弹簧框架。 Documentation表示它是可行的,但示例show interface不扩展Repository基类。

我知道有一个注释@Query可以定义自定义查询,但是如果我想为该类添加例如Criteria查询呢?此外,我希望像findAll这样的方法留在存储库中。

这是我尝试的。首先,我为Post实体创建了存储库:

package foo.bar.repository;

import foo.bar.model.Post;
import org.springframework.data.repository.CrudRepository;

public interface PostRepository extends CrudRepository<Post, Long> {

}

然后我创建了扩展接口并将自定义方法添加到它的抽象实现类:

package foo.bar.repository;

public abstract class PostRepositoryImpl implements PostRepository {

    public List<Post> someCustomMethod() {
        //some logic here
    }

}

这样做甚至可行吗?也许还有其他方法可以在hibernate中做到这一点。我长时间使用Doctrine,这是基于休眠的。在那里,您只需扩展基本存储库类并添加所需的方法。

1 个答案:

答案 0 :(得分:2)

我将添加一个执行自定义查询的自定义方法的示例。我希望我理解你对你的问题意味着什么。

<强> PersonRepository

public interface PostRepository extends CrudRepository<Post, Long>{
    List<Post> getPostsOlderThanDate(Date date);
}

<强> PersonRepositoryImpl

import org.springframework.data.jpa.repository.support.SimpleJpaRepository;

import javax.persistence.EntityManager;
import javax.persistence.TypedQuery;
import java.util.Date;
import java.util.List;

public class PostRepositoryImpl extends SimpleJpaRepository<Post, Long> implements PostRepository {

    private EntityManager entityManager;

    public PostRepositoryImpl(EntityManager em) {
        super(Post.class, em);
        this.entityManager = em;
    }

    @Override
    public List<Post> getPostsOlderThanDate(Date date) {
        String query = ""; //create query
        TypedQuery<Post> typedQuery = entityManager.createQuery(query, Post.class);
        return typedQuery.getResultList();
    }
}

然后创建您的EntityManagerFactory bean(使用Hibernate持久性提供程序构建,或者您设置它,它取决于您),并将其注入PersonRepositoryImpl bean的构造函数。

<bean id="personRepository" class="com.package.PersonRepositoryImpl">
    <constructor-arg ref="entityManagerFactory" />
</bean>

这些是向数据库提供一些自定义查询的步骤。

注意:如果您在设置EntityManager时需要帮助,只需留下评论给我,我就会给你弹簧配置和依赖项。