我想为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,这是基于休眠的。在那里,您只需扩展基本存储库类并添加所需的方法。
答案 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时需要帮助,只需留下评论给我,我就会给你弹簧配置和依赖项。