首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JPA继承问题,为什么生成的查询在wildfly10和jboss7之间不同

JPA(Java Persistence API)是Java持久化规范,用于将Java对象持久化到数据库中。在JPA中,继承关系是一个常见的问题,特别是在不同的应用服务器(如wildfly10和jboss7)之间可能会出现生成查询不同的情况。下面是对这个问题的完善且全面的答案:

继承问题是指在JPA中,当实体类之间存在继承关系时,生成的查询在不同的应用服务器之间可能会有差异。这是因为不同的应用服务器可能使用不同的JPA实现,或者使用不同的配置参数,导致生成的查询语句不同。

在JPA中,继承关系可以通过三种方式来实现:单表继承、表格继承和混合继承。这些继承策略决定了实体类在数据库中的映射方式,以及生成的查询语句。

  1. 单表继承(Single Table Inheritance):所有的实体类都映射到同一个数据库表中,通过一个类型字段来区分不同的实体类。这种继承策略生成的查询语句相对简单,但当实体类较多时,表的字段可能会很冗余。
  2. 表格继承(Table Per Class Inheritance):每个实体类都映射到独立的数据库表中,子类表包含了父类表的所有字段。这种继承策略生成的查询语句相对复杂,但表的结构更加规范。
  3. 混合继承(Joined Inheritance):每个实体类都映射到独立的数据库表中,子类表只包含了子类特有的字段,通过外键关联到父类表。这种继承策略生成的查询语句相对复杂,但表的结构更加规范,查询性能也较好。

在wildfly10和jboss7之间生成查询不同的原因可能有以下几点:

  1. JPA实现版本不同:wildfly10和jboss7可能使用了不同版本的JPA实现,不同版本的JPA实现可能对继承关系的处理方式有所差异,导致生成的查询语句不同。
  2. 配置参数不同:wildfly10和jboss7可能使用了不同的配置参数,如继承策略、表名生成规则等,这些配置参数的不同也会导致生成的查询语句不同。
  3. 应用服务器差异:wildfly10和jboss7是不同的应用服务器,它们可能对JPA规范的实现方式有所差异,这也会导致生成的查询语句不同。

针对这个问题,可以通过以下方式解决:

  1. 确保使用相同的JPA实现版本:在wildfly10和jboss7中都使用相同版本的JPA实现,可以减少生成查询不同的可能性。
  2. 统一配置参数:在wildfly10和jboss7中使用相同的配置参数,特别是继承策略、表名生成规则等,可以保持生成的查询语句一致。
  3. 调整应用服务器配置:如果wildfly10和jboss7的配置差异较大,可以尝试调整应用服务器的配置,使其在处理继承关系时更加一致。

总结起来,JPA继承问题是指在不同的应用服务器中生成的查询语句不同的情况。这可能是由于JPA实现版本、配置参数和应用服务器差异等原因导致的。为了解决这个问题,需要统一JPA实现版本、配置参数,并可能需要调整应用服务器的配置。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

SpringDataJPA 系列之 JPA 简介

对象和关系数据是业务实体的两种表现形式,业务实体在内存中表现为对象,在数据库中表现为关系数据。内存中的对象之间存在关联和继承关系,而在数据库中,关系数据无法直接表达多对多关联和继承关系。...1.2 JPA 简介 1.2.1 概述   我们都知道不同的数据库厂商都有自己的实现类,后来统一规范也就有了数据库驱动, Java 在操作数据库的时候,底层使用的其实是 JDBC,而 JDBC 是一组操作不同数据库的规范...开发的企业应用能够经过少量的修改就能够在不同的 JPA 框架下运行。...JPA 基于非侵入式原则设计,因此可以很容易的和其它框架或者容器集成 ☞ 查询能力   JPA 的查询语言是面向对象而非面向数据库的,它以面向对象的自然语法构造查询语句,可以看成是 Hibernate...☞ 高级特性   JPA 中能够支持面向对象的高级特性,如类之间的继承、多态和类之间的复杂关系,这样的支持能够让开发者最大限度的使用面向对象的模型设计企业应用,而不需要自行处理这些特性在关系数据库的持久化

4.4K20

ORM和 Spring Data Jpa

什么是ORM 即Object-Relationl Mapping,它的作用是在关系型数据库和对象之间作一个映射,这样,我们在具体的操作数据库的时候,就不需要再去和复杂的SQL语句打交道,只要像平时操作对象一样操作它就可以了...为什么要做持久化和ORM设计(重要) 在目前的企业应用系统设计中,MVC,即 Model(模型)- View(视图)- Control(控制)为主要的系统架构模式。...JPA的优势 标准化: 提供相同的 API,这保证了基于JPA 开发的企业应用能够经过少量的修改就能够在不同的 JPA 框架下运行。...支持面向对象的高级特性: JPA 中能够支持面向对象的高级特性,如类之间的继承、多态和类之间的复杂关系,最大限度的使用面向对象的模型 5....JPQL 是一种和 SQL 非常类似的中间性和对象化查询语言,它最终会被编译成针对不同底层数据库的 SQL 查询,从而屏蔽不同数据库的差异。

3.4K30
  • 干货|一文读懂 Spring Data Jpa!

    其实这个话题松哥以前零零散散的介绍过,在我的书里也有介绍过,但是在公众号中还没和大伙聊过,因此本文就和大家来仔细聊聊 Spring Data 和 Jpa! 故事的主角 Jpa 1....JPA的优势 标准化: 提供相同的 API,这保证了基于JPA 开发的企业应用能够经过少量的修改就能够在不同的 JPA 框架下运行。...支持面向对象的高级特性: JPA 中能够支持面向对象的高级特性,如类之间的继承、多态和类之间的复杂关系,最大限度的使用面向对象的模型 5....JPQL 是一种和 SQL 非常类似的中间性和对象化查询语言,它最终会被编译成针对不同底层数据库的 SQL 查询,从而屏蔽不同数据库的差异。...3.查询方法流程解析 为什么写上方法名,JPA就知道你想干嘛了呢?

    2.8K20

    浅谈JPA优缺点_sql优点

    总的来说,JPA包括以下3方面的技术: ORM映射元数据,JPA支持XML和JDK 5.0注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象持久化到数据库表中; JPA的API,...性能问题 采用JDBC编程,在很多时候存在效率低下的问题。例如程序将向后台数据库发送1000次SQL语句执行请求,运行效率较低。...如下特点: 标准化 JPA 是 JCP 组织发布的 Java EE 标准之一,因此任何声称符合 JPA 标准的框架都遵循同样的架构,提供相同的访问 API,这保证了基于JPA开发的企业应用能够经过少量的修改就能够在不同的...简单易用,集成方便 JPA的主要目标之一就是提供更加简单的编程模型:在JPA框架下创建实体和创建Java 类一样简单,没有任何的约束和限制,只需要使用 javax.persistence.Entity...支持面向对象的高级特性 JPA 中能够支持面向对象的高级特性,如类之间的继承、多态和类之间的复杂关系,这样的支持能够让开发者最大限度的使用面向对象的模型设计企业应用,而不需要自行处理这些特性在关系数据库的持久化

    1.7K20

    Spring Boot2 系列教程(二十三)理解 Spring Data Jpa

    其实这个话题松哥以前零零散散的介绍过,在我的书里也有介绍过,但是在公众号中还没和大伙聊过,因此本文就和大家来仔细聊聊 Spring Data 和 Jpa! 本文大纲: ? 1....EclipseLink 1.1.4 JPA 的优势 标准化: 提供相同的 API,这保证了基于 JPA 开发的企业应用能够经过少量的修改就能够在不同的 JPA 框架下运行。...支持面向对象的高级特性: JPA 中能够支持面向对象的高级特性,如类之间的继承、多态和类之间的复杂关系,最大限度的使用面向对象的模型 1.1.5 JPA 包含的技术 ORM 映射元数据:JPA 支持 XML...JPQL 是一种和 SQL 非常类似的中间性和对象化查询语言,它最终会被编译成针对不同底层数据库的 SQL 查询,从而屏蔽不同数据库的差异。...2.2.3.3 查询方法流程解析 为什么写上方法名,JPA就知道你想干嘛了呢?

    2K10

    Spring Data JPA 就是这么简单

    java 操作实体类的时候能达到操作数据库中表的效果(不用写sql ,就可以达到效果),jpa 的实现思想即是 ORM (Object Relation Mapping),对象关系映射,用于在关系型数据库和业务实体对象之间作一个映射...使用上述实体类的注解,当运行项目的时候就会在数据库中生成一个表名是 stu 的表。 类的继承分析 下面来研究一下类之间存在继承关系的时候,jpa 又是如何处理继承关系的呢?...大致总结继承这块有这样三种情况: 多类一表:多个类之间的属性相同,唯一的区别就是类型上的差异(类名不同),这个时候我们可以为这个共同属性的类建立一个父类,只让父类应射到数据库。...类之间的关系分析 在数据库当中表和表之间都是有一定的关联关系的,jpa 是如何在实体类之间建立和数据库表中类似的关联关系呢?...小结:类和类之间的关系在 jpa 中很重要,务必要搞清楚,以上展示代码可参考个人仓库 https://github.com/kickcodeman/spring-data-jpa,可以 clone 下来

    7K50

    持久层框架JPA与Mybatis该如何选型

    图中蓝色线条为Mybatis搜索量,绿色为JPA搜索量。如果你换一个国外的搜索指数,你会得到一个完全不同的结果。那么这是为什么呢?...所谓的动态SQL就是:根据传入参数条件的不同,构造不同的SQL,很多的比较这两个框架的文章都忽略了动态SQL的问题,这方面Mybatis支持的更好。...说完以上几点,Mybatis为什么在国内会有如此多的使用者及使用厂商就不难理解了。Mybatis还可以使用如:Mybatis-plus或者代码自动生成来弥补易用性上的不足。...四、框架对比选型 对比项 Spring Data JPA Mybatis 单表操作方式 只需继承,代码量极少,非常方便。...这个技术选型在国内通常是Mybatis。 如果你们公司的管理非常规范,微服务落地经验也非常成熟,可以考虑在团队项目中使用JPA。少用或不用关联查询。 喜欢 (5)or分享 (0)

    2.1K41

    再见 MyBatis!我选择 JDBCTemplate!

    不管是hibernate还是jpa,表之间的连接查询,被映射为实体类之间的关联关系,这样,如果两个实体类之间没有(实现)关联关系,你就不能把两个实体(或者表)join起来查询。...后来的JOOQ和Ebean,基本上继承了QueryDSL的思路,Ebean基本上还是JPA风格的ORM框架,虽然也支持SQL,但不清楚其DSL特性是否支持SQL语句编写,在官网上看到的例子都是用于构造JPQL...和Ebean,需要了解复杂的JPA概念和各种奇异的限制,JOOQ编写的就是普通的SQL语句,只是把查询结果填充到实体类中(严格说JOOQ没有实体类,只是自动生成的Record对象),JOOQ甚至不一定要把结果转换为实体类...三、跨数据库移植 Hibernate和JPA使用hql和JPQL这类数据库无关的中间语言描述查询,可以在不同数据库中无缝移植,移植到一个SQL有巨大差别的数据库通常不需要修改代码或者只需要修改很少的代码...JOOQ根据目标数据库转换SQL语句的特性,使得在不同数据库之间移植的时候,只需要修改很少的代码,明显优于MyBatis。

    2.9K40

    再见!Mybatis,你好!JDBCTemplate

    不管是hibernate还是jpa,表之间的连接查询,被映射为实体类之间的关联关系,这样,如果两个实体类之间没有(实现)关联关系,你就不能把两个实体(或者表)join起来查询。...后来的JOOQ和Ebean,基本上继承了QueryDSL的思路,Ebean基本上还是JPA风格的ORM框架,虽然也支持SQL,但不清楚其DSL特性是否支持SQL语句编写,在官网上看到的例子都是用于构造JPQL...和Ebean,需要了解复杂的JPA概念和各种奇异的限制,JOOQ编写的就是普通的SQL语句,只是把查询结果填充到实体类中(严格说JOOQ没有实体类,只是自动生成的Record对象),JOOQ甚至不一定要把结果转换为实体类...三、跨数据库移植 Hibernate和JPA使用hql和JPQL这类数据库无关的中间语言描述查询,可以在不同数据库中无缝移植,移植到一个SQL有巨大差别的数据库通常不需要修改代码或者只需要修改很少的代码...JOOQ根据目标数据库转换SQL语句的特性,使得在不同数据库之间移植的时候,只需要修改很少的代码,明显优于MyBatis。

    3.9K10

    放弃 MyBatis、JPA,我最终选择了 JDBC Template!真香!!

    不管是hibernate还是jpa,表之间的连接查询,被映射为实体类之间的关联关系,这样,如果两个实体类之间没有(实现)关联关系,你就不能把两个实体(或者表)join起来查询。...后来的JOOQ和Ebean,基本上继承了QueryDSL的思路,Ebean基本上还是JPA风格的ORM框架,虽然也支持SQL,但不清楚其DSL特性是否支持SQL语句编写,在官网上看到的例子都是用于构造JPQL...和Ebean,需要了解复杂的JPA概念和各种奇异的限制,JOOQ编写的就是普通的SQL语句,只是把查询结果填充到实体类中(严格说JOOQ没有实体类,只是自动生成的Record对象),JOOQ甚至不一定要把结果转换为实体类...三、跨数据库移植 Hibernate和JPA使用hql和JPQL这类数据库无关的中间语言描述查询,可以在不同数据库中无缝移植,移植到一个SQL有巨大差别的数据库通常不需要修改代码或者只需要修改很少的代码...JOOQ根据目标数据库转换SQL语句的特性,使得在不同数据库之间移植的时候,只需要修改很少的代码,明显优于MyBatis。

    3.4K10

    放弃MyBatis!我选择 JDBCTemplate!

    不管是hibernate还是jpa,表之间的连接查询,被映射为实体类之间的关联关系,这样,如果两个实体类之间没有(实现)关联关系,你就不能把两个实体(或者表)join起来查询。...后来的JOOQ和Ebean,基本上继承了QueryDSL的思路,Ebean基本上还是JPA风格的ORM框架,虽然也支持SQL,但不清楚其DSL特性是否支持SQL语句编写,在官网上看到的例子都是用于构造JPQL...和Ebean,需要了解复杂的JPA概念和各种奇异的限制,JOOQ编写的就是普通的SQL语句,只是把查询结果填充到实体类中(严格说JOOQ没有实体类,只是自动生成的Record对象),JOOQ甚至不一定要把结果转换为实体类...三、跨数据库移植 Hibernate和JPA使用hql和JPQL这类数据库无关的中间语言描述查询,可以在不同数据库中无缝移植,移植到一个SQL有巨大差别的数据库通常不需要修改代码或者只需要修改很少的代码...JOOQ根据目标数据库转换SQL语句的特性,使得在不同数据库之间移植的时候,只需要修改很少的代码,明显优于MyBatis。

    16110

    SpringDataJPA 系列之快速入门

    ) 完成操作,这样在切换不同的 ORM 框架时提供了极大的方便,同时也使数据库层操作更加简单,方便解耦 ?...1.1.2 SpringDataJPA 与 JPA 和 hibernate 之间的关系   JPA 是一套规范,内部是有接口和抽象类组成的。...hibernate 是一套成熟的 ORM 框架,而且 Hibernate 实现了 JPA 规范,所以也可以称 hibernate 为 JPA 的一种实现方式,我们使用 JPA 的 API 编程,意味着站在更高的角度上看待问题...一般我们会继承 JpaRepository 和 JpaSpecificationExecutor 接口,我们可以使用接口中定义的方法进行查询。   ...只需要按照 SpringDataJPA 提供的方法命名规则定义方法的名称,就可以完成查询工作。SpringDataJPA 在程序执行的时候会根据方法名称进行解析,并自动生成查询语句进行查询。

    1.6K30

    SpringBoot教程(十二) | SpringBoot集成JPA

    优势: 标准化 JPA 是 JCP 组织发布的 Java EE 标准之一,因此任何声称符合 JPA 标准的框架都遵循同样的架构,提供相同的访问API,这保证了基于JPA开发的企业应用能够经过少量的修改就能够在不同的...简单方便 JPA的主要目标之一就是提供更加简单的编程模型:在JPA框架下创建实体和创建Java 类一样简单,没有任何的约束和限制,只需要使用 javax.persistence.Entity进行注释,JPA...高级特性 JPA 中能够支持面向对象的高级特性,如类之间的继承、多态和类之间的复杂关系,这样的支持能够让开发者最大限度的使用面向对象的模型设计企业应用,而不需要自行处理这些特性在关系数据库的持久化。...查看数据库: 时间值没有,因为我们没有在新增的时候设置当前时间。 再试试修改和查询 查询 4.6 自定义SQL的执行 现在我们的DAO层用的是JPA自带的通过继承一个基类的常用操作来实现的。...关于JPA和Mybatis的选择问题,这个之一在网络上争论不断,这个其实也没有什么好坏之分,是要能实现我们的目的,选择那种框架只不过是其中的一种手段罢了。

    3.3K10

    另一种思考:为什么不选JPA、MyBatis,而选择JDBCTemplate?

    不管是hibernate还是jpa,表之间的连接查询,被映射为实体类之间的关联关系,这样,如果两个实体类之间没有(实现)关联关系,你就不能把两个实体(或者表)join起来查询。...后来的JOOQ和Ebean,基本上继承了QueryDSL的思路,Ebean基本上还是JPA风格的ORM框架,虽然也支持SQL,但不清楚其DSL特性是否支持SQL语句编写,在官网上看到的例子都是用于构造JPQL...和Ebean,需要了解复杂的JPA概念和各种奇异的限制,JOOQ编写的就是普通的SQL语句,只是把查询结果填充到实体类中(严格说JOOQ没有实体类,只是自动生成的Record对象),JOOQ甚至不一定要把结果转换为实体类...三、跨数据库移植 Hibernate和JPA使用hql和JPQL这类数据库无关的中间语言描述查询,可以在不同数据库中无缝移植,移植到一个SQL有巨大差别的数据库通常不需要修改代码或者只需要修改很少的代码...JOOQ根据目标数据库转换SQL语句的特性,使得在不同数据库之间移植的时候,只需要修改很少的代码,明显优于MyBatis。

    2.6K20

    2018-12-13 java – Spring数据JPA中的CrudRepository和JpaRepository接口之间的区别

    java – Spring数据JPA中的CrudRepository和JpaRepository接口之间的区别 在Spring Data JPA中的CrudRepository和JpaRepository...它们之间有什么区别?你为什么要使用一个在另一个? JpaRepository延伸PagingAndSortingRepository,其继而延伸CrudRepository。...任何人都可以告诉我JTA,JPA和平面JDBC在hibernate方面有什么区别?我一直被问到这个问题,我在提出答案的时候发现了。...Hibernate实现了JPA标准 plain JDBC是一种用于访问数据库的技术。这是Hibernate实际用来执行数据库操作,“在引擎盖下”。它使用JDBC将查询发送到数据库。...转载注明原文:java – Hibernate中JTA,JPA和Plain JDBC之间的区别

    2.7K20

    快速学习-hibernate与JPA的概述

    ,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。...2.3 JPA的优势 标准化 JPA 是 JCP 组织发布的 Java EE 标准之一,因此任何声称符合 JPA 标准的框架都遵循同样的架构,提供相同的访问API,这保证了基于JPA开发的企业应用能够经过少量的修改就能够在不同的...简单方便 JPA的主要目标之一就是提供更加简单的编程模型:在JPA框架下创建实体和创建Java 类一样简单,没有任何的约束和限制,只需要使用 javax.persistence.Entity进行注释,...JPA基于非侵入式原则设计,因此可以很容易的和其它框架或者容器集成 查询能力 JPA的查询语言是面向对象而非面向数据库的,它以面向对象的自然语法构造查询语句,可以看成是Hibernate HQL...高级特性 JPA 中能够支持面向对象的高级特性,如类之间的继承、多态和类之间的复杂关系,这样的支持能够让开发者最大限度的使用面向对象的模型设计企业应用,而不需要自行处理这些特性在关系数据库的持久化。

    1.3K10

    SpringDataA和Mybaits有什么区别,如何使用?

    SpringDataJPA和Mybaits 什么是JPA jpq是面向对象的思想,一个对象就是一个表,强化的是你对这个表的控制。jpa继承的那么多表约束注解也证明了jpa对这个数据库对象控制很注重。...其实,在阿粉的眼中,JPA好像就是和Hibernate是一样的东西,区别并不大。 Spring Data JPA是Spring Data的子模块。...作为使用者,我们只需要编写自己的repository接口,接口中包含一些个性化的查询方法,Spring Data JPA将自动实现查询方法. 也就是说是什么呢?...Mybaits 的文件,比如直接通过你建立的表生成 Dao文件和 dao.xml文件。...有问题就改嘛,这才是好朋友。 看阿粉启动的还是相对来说很成功的,接下来我们就得安排一下这个 JPa 的使用方式了。

    95240

    spring boot 中使用 jpa以及jpa介绍

    2.1标准化 JPA 是 JCP 组织发布的 Java EE 标准之一,因此任何声称符合 JPA 标准的框架都遵循同样的架构,提供相同的访问API,这保证了基于JPA开发的企业应用能够经过少量的修改就能够在不同的...2.3简单方便 JPA的主要目标之一就是提供更加简单的编程模型:在JPA框架下创建实体和创建Java 类一样简单,没有任何的约束和限制,只需要使用 javax.persistence.Entity进行注释...2.4高级特性 JPA 中能够支持面向对象的高级特性,如类之间的继承、多态和类之间的复杂关系,这样的支持能够让开发者最大限度的使用面向对象的模型设计企业应用,而不需要自行处理这些特性在关系数据库的持久化...@OneToOne 定义了连接表之间有一个一对一的关系。 @NamedQueries 指定命名查询的列表。 @NamedQuery 指定使用静态名称的查询。...那么JPA是通过什么规则来根据方法名生成sql语句查询的呢?

    4.5K10

    Jpa使用详解

    标准化 JPA 是 JCP 组织发布的 Java EE 标准之一,因此任何声称符合 JPA 标准的框架都遵循同样的架构,提供相同的访问API,这保证了基于JPA开发的企业应用能够经过少量的修改就能够在不同的...简单方便 JPA的主要目标之一就是提供更加简单的编程模型:在JPA框架下创建实体和创建Java 类一样简单,没有任何的约束和限制,只需要使用 javax.persistence.Entity进行注释,...查询能力 JPA的查询语言是面向对象而非面向数据库的,它以面向对象的自然语法构造查询语句,可以看成是Hibernate HQL的等价物。...高级特性 JPA 中能够支持面向对象的高级特性,如类之间的继承、多态和类之间的复杂关系,这样的支持能够让开发者最大限度的使用面向对象的模型设计企业应用,而不需要自行处理这些特性在关系数据库的持久化。...(即多个线程访问同一个EntityManagerFactory 对象不会有线程安全问题),并且EntityManagerFactory 的创建极其浪费资源,所以在使用JPA编程时,我们可以对EntityManagerFactory

    3.3K20

    Spring Data Jpa初体验(内含demo)

    ORM 对象关系映射,即Object Relational Mapping,简称ORM.是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换....开发者还可以直接在声明的方法上面使用 @Query 注解,并提供一个查询语句作为参数,Spring Data JPA 在创建代理对象时,便以提供的查询语句来实现其功能。...实际测试我才发现,许多的方法在继承的接口中早已定义,比如查询全量,根据主键嗯增删改查,排序,分页等,可谓十分强大,因此简单测试了大于小于及多参数的查询. 以下代码实际运行通过....后话 在今天的学习后,对Jpa也算是有一点了解,在我看来,他和Mysql是两种不同的思路,但是都可以完成同一个任务....附录:方法关键字和使用方式及生成的SQL列表 Keyword Sample JPQL snippet And findByLastnameAndFirstname … where x.lastname

    98130
    领券