草庐IT

java - Spring:缺少 JPA 元模型

我无法理解带有JPA存储库的简单SpringMVC项目出了什么问题。能否给个提示。域:packagecom.test.app;@Entity@Table(name="foo_table")publicclassFooDomain{@Id@Column(name="id",unique=true,nullable=false)privateIntegerid;@Column(name="text",nullable=false)privateStringtext;//getters&settershere...存储库packagecom.test.app;@RepositoryDefin

java - 如何使用 Hibernate 支持的 JPA 在 tomcat 中运行 Spring 3.0 PetClinic

好吧,这应该是世界上最简单的事情了,但我已经尝试了一整天,但仍然没有用。非常感谢任何帮助!编辑:有关正确的程序,请参阅Pascal的回答。我的错误(因为我没有禁用LoadTimeWeaving)程序留作引用..:我做了什么:已下载Tomcat6.0.26和Spring3.0.1从https://src.springframework.org/svn/spring-samples/petclinic下载PetClinic构建并部署了petclinic.war。使用默认的JDBC持久性运行良好。编辑webapps/WEB-INF/spring/applicationContext-jpa.

Java 请求占用 40-50MB 内存(Spring JPA Hibernate)

我正在使用带有JPAHibernate的springboot。我正在监控Heap服务,发现我的每个请求都占用了大约40-50MB。所以内存会增加,在GC运行几次请求后,它会释放内存,并且这种情况会一直持续下去。所以我的第一个问题是这是内存泄漏吗?我也在尝试找出造成这种情况的原因。因此,我使用Runtime.getRuntime()freeMemory和totalMemory()来确定在获取一个数据库调用并用它填充投影时大约使用了15MBpublicinterfaceRecommendationProjection{publicStringgetType();publicbooleang

java - 如何在 JPA 中映射自定义集合?

我在使用JPA(Hiberante提供程序)映射自定义集合时遇到问题。例如当我使用带有属性的对象时Listmatches;与在我的ORM文件中,没问题;但是,如果我将"Listmatches;"替换为privateMatchesmatches;,其中“匹配”定义如下:publicclassMatchesextendsArrayList{privatestaticfinallongserialVersionUID=1L;}它产生以下错误:Causedby:org.hibernate.AnnotationException:Illegalattempttomapanoncollection

java - NamedEntityGraph - JPA/Hibernate 抛出 org.hibernate.loader.MultipleBagFetchException : cannot simultaneously fetch multiple bags

我们有一个项目需要延迟加载实体的集合,但在某些情况下我们需要急切加载它们。我们为我们的实体添加了一个@NamedEntityGraph注释。在我们的存储库方法中,我们添加了一个“javax.persistence.loadgraph”提示以急切地加载在所述注释中定义的4个属性。当我们调用该查询时,Hibernate抛出org.hibernate.loader.MultipleBagFetchException:cannotsimultaneousfetchmultiplebags。有趣的是,当我将所有这些集合重新定义为急切获取时,Hibernate确实会急切获取它们,而不会出现Mult

java - 使用 JPA 时如何在没有主键的情况下映射数据库 View

我在没有明显主键(复合或其他)的SQL数据库中有View我想通过JPA访问它们我读到我应该能够像对待表格一样对待JPA中的View(使用@Table注释等)。但是,如果没有主键,我必须有效地从每一列中创建一个复合键(事实上,这在Hibernate的逆向工程工具默认情况下似乎是这样做的)。但是,如果我这样做,会产生不良的副作用。例如必须编写指向主键属性而不是View的所有代码:myViewObject.getPrimaryKey().getFirstName()无法在spring存储库上使用“findBy...”方法(因为该属性是View“标识符”的一部分,而不是它的实际属性之一)。我的

java - 如何防止 JPA 回滚事务?

调用的方法:1.StrutsAction2.服务类方法(@Transactional注解)3.Xfireweb服务调用包括struts(DelegatingActionProxy)和事务在内的一切都使用Spring配置。持久化是通过JPA/Hibernate完成的。有时网络服务会抛出未经检查的异常。我捕获了这个异常并抛出了一个已检查的异常。我不希望事务回滚,因为Web服务异常更改了当前状态。我已经注释了这样的方法:@Transactional(noRollbackFor={XFireRuntimeException.class,Exception.class})publicAction

java - JPA 与 JDBC、存储过程和 Co. 或如何说服老派程序员尝试 ORM?

这是我定期处理的事情,也是我第一次需要说服。幸运的是,我刚刚尝试过,付出了额外的努力来学习并感谢thisbook、Spring支持和Hibernate我不会在不考虑JPA的情况下开始一个项目。但并不是每个人都愿意经常加倍努力(我猜只是在我们处理的任何事情上)。那么如何以及应该说/呈现/解释/论证什么来至少改变他们对ORM的态度?相关:ConvincingadiehardDBAtouseanORMforthemajorityofCRUDvsStoredProcedures,View,andFunctions 最佳答案 我假设您实际上拥

java - 如何将 Java 中的二维矩阵映射到 Hibernate/JPA?

我有一个遗留数据库,我正试图重新设计以适应21世纪。现有的数据结构之一涉及一个特定的类,它包含一个二维值矩阵。如果我要从数据库中对此类进行逆向工程,我最终会得到一系列属性,例如:privateBigDecimalNODE_1_MATRIX_POS_1_1;privateBigDecimalNODE_1_MATRIX_POS_1_2;等等。由于这是一个6x6矩阵,因此有很多这样的列。我一直在寻找更好的方法,但我不确定我在那里。我想做的是这样的:@EntitypublicclassTestClass{@Idprivatelongid;@CollectionOfElements@JoinTa

java - JPA的cascade=REMOVE和Hibernate的@OnDelete一起用?

我继承了一个代码库,几乎所有关系都有以下注释:@OneToMany(fetch=FetchType.LAZY,cascade={CascadeType.REMOVE},mappedBy="someThing")@OnDelete(action=OnDeleteAction.CASCADE)现在我很难理解@OnDelete首先做了什么。Hibernate:OnDeletevscascade=CascadeType.REMOVE很有趣,但遗憾的是没有任何答案,@OnDelete的JavaDoc特别毫无值(value)。从其他问题来看,OnDelete注释似乎让DB以某种方式进行级联,而@O