hibernate-entitymanager
全部标签 什么是测试DAO层的正确方法?我在创建和销毁SessionFactory时使用了@BeforeMethod和@AfterMethod注释方法,但它不适用于多个测试。如果测试一个接一个地运行,但当它们一起运行时没有使用maven构建,所以我决定我应该使用TestNg组对它们进行分组并执行@BeforeGroup和@AfterGroup方法,其中我对Hibernate做了同样的事情。所以我做了这样的事情:@Test(groups={"integration"})publicclassIntegrationTest{protectedSessionFactorysessionFactory;
在我的Web应用程序中,我在ApacheTomcat(TomEE)/7.0.37服务器上使用OpenJPA。我使用Netbeans自动生成类(“来自数据库的实体类...”和“来自实体类的sessionBean...”)。在SessionBean(例如UserFacade)我想得到EntityManager:@StatelesspublicclassUserFacadeextendsAbstractFacade{@PersistenceContext(unitName="CollDocPU")privateEntityManagerem;@OverrideprotectedEntityM
我正在致力于实现某些静态数据的缓存。我有两种方法:使用Spring框架注释使用方法级缓存。启用二级缓存,以便hibernate管理数据缓存哪种方法效果最好?我必须考虑哪些事项? 最佳答案 如果一切都平等考虑更喜欢方法调用结果的Spring缓存,原因是在服务层级别进行缓存更容易推理。Hibernate二级缓存工作正常,但在我看来它更难推理并且有更多缺陷。例如,它不适用于查询,仅适用于通过ID查找或加载惰性关联。实际上惰性关联的加载默认情况下是关闭的,需要在集合级别使用特定于hibernate的注释来启用。要查询查询的结果,您还需要使用
我试图避免为计数创建一个单独的查询,为实际查询创建一个单独的查询。我发现SessionImpl::createQuery需要花费大量时间进行复杂查询,然后通过结合计数和主查询,我可以消除一个createQuery调用。在SQL中我可以做类似的事情selectcount(*)over(),col_A,col_BfromTABLE_XXwherecol_C>1000hibernate可以实现吗?(我试图避免使用原生sql并坚持使用HQL和分离条件。使用原生SQL违背了使用hibernate的目的。我的系统必须同时支持Oracle和Sybase) 最佳答案
假设我有一个如下所示的Hibernate/JPA实体:@EntitypublicclassFooEntity{...@Type(type="hstore")HashMaptags;}...和hstore类型是来自this的简单UserType实现资源。有没有一种方法可以在类似于此伪代码的JPQL查询中访问hstore:SELECTfFROMFooEntityfWHEREf.tagsCONTAINSKEY(:key) 最佳答案 您也可以简单地创建一个Hibernateorg.hibernate.usertype.UserType。你扩
我有以下问题。在我正在开发的应用程序中,我们使用Hibernate,每个查询都是用CriteriaAPI编写的。现在,在某些地方,我们希望增加用户编写一些SQL代码的可能性,这些代码将用作查询中where子句的一部分。所以基本上,用户可以按照自己的方式从数据库中过滤显示给他的数据。几天来,我一直在努力寻找一种方法来修改我们以前的查询以获得上述结果。这是我所知道的:看起来您无法将CriteriaAPI与nativeSQL结合使用。您可以用SQL编写整个查询或仅使用条件API。那正确吗?我问这个问题是因为它是最简单的解决方案,只需将此SQL代码用作我们查询中where子句中的另一个谓词。但
我正在尝试通过复合键执行多个连接。我正在使用别名来强制创建连接,但似乎连接不是由Hibernate生成的。我不知道为什么会这样。我可以让它与nativeSQL查询一起使用,但在使用条件时无法使用。我怀疑这可能与复合键定义的映射方式有关(参见BusinessServiceUser上的associationOverrides)下面是我的域模型类和查询信息。欢迎任何想法:)商务服务@Entity@Table(name="business_services")publicclassBusinessServiceextendsAbstractEntityimplementsSerializabl
已编辑。虽然扩展基础存储库类并添加插入方法会起作用,但更优雅的解决方案似乎是在实体中实现Persistable。查看可能的解决方案2我正在使用springframework.data.jpa创建一个服务,使用JpaTransactionManager将Hibernate作为ORM。遵循此处教程的基础。http://www.petrikainulainen.net/spring-data-jpa-tutorial/我的实体存储库扩展org.springframework.data.repository.CrudRepository我正在使用一个遗留数据库,它使用有意义的主键而不是自动生成
我读到的关于Hibernate的所有内容都指出,当发生错误时,您必须回滚事务并关闭session,并且以下代码(取自Hibernate的文档)通常有一些变体作为示例:Sessionsess=factory.openSession();Transactiontx=null;try{tx=sess.beginTransaction();//dosomework...tx.commit();}catch(RuntimeExceptione){if(tx!=null)tx.rollback();throwe;//ordisplayerrormessage}finally{sess.close(
我有这样一个Hibernate服务方法:"SELECTscFROMSecurityContactscWHEREsc.securityId=:securityId2"。securityId2由用户传入。每个SecurityContact都与一个Contact具有多对一的关系,因此Hibernate会在该查询运行时自动调用连接。但是,Hibernate始终运行的连接是一个内部连接,对于我的目的来说它不能正常工作。有什么办法可以强制Hibernate在内部生成左外连接吗?下面是SecurityContact类的代码:/***ThepersistentclassfortheSecurityCo