- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
EclipseLink 的奇怪行为(Eclipse Persistence Services - 2.1.1.v20100817-r8050),我有一个 false(虚拟/不是数据库中的实际表)实体类来保存从 createNativeQuery(query,entity.class) 返回的结果集 @实体 公共(public)类 VirtualTable 实现可序列化 { 私有(private)静态最终长serialVersionUID = 1L;
@Id
@Column(name = "ROW")
private Integer row;
@Column(name = "ABC")
private String abc= null
@Column(name = "XYZ")
private String xyz= null
下面是我获取结果集的代码我已将entityClass 设置为VirtualTable.class
/**
* Get a list of entity objects by a native query.
*
* @param nativeQueryString the query.
* @param qryParamList the parameters for the query. Must be in the same order as listed in the query.
* @param entityClass the Class of the entity object. The entityClass field must be mapped to the
* column names from the query result set.
* @return a list of entity object of class entityClass
*/
@SuppressWarnings("rawtypes")
public static List getObjectListByNativeQuery(String nativeQueryString,
List<Object> qryParamList, Class entityClass) {
EntityManager em = ReportRepository.getEntityManager(SqlConstants.PERSISTENCE_UNIT_NAME_PODR_RPT );
//populate the parameter list
logger.info("em test inside query"+ em.hashCode() +" "+nativeQueryString + ", with ref class: " + entityClass.getName());
Query query = em.createNativeQuery(nativeQueryString, entityClass);
if(qryParamList != null && qryParamList.size() > 0) {
for(int i=0; i< qryParamList.size(); i++) {
Object param = qryParamList.get(i);
//the native query parameters must start with 1
query.setParameter(i+1, param);
}
}
List resultList = query.getResultList();
return resultList;
}enter code here
在返回结果集之前,JPA 尝试自行触发查找查询,并且由于该表不在数据库中,因此它会抛出表未找到的错误。我在 persistence.xml 中使用 SOFT 缓存,而不是它是一个简单的 JPA 实现。请让我知道如何避免 JPA 对此特定实体类进行查询并定义它不是实际的数据库表。我想避免手动映射,我不会在任何地方保留这个虚拟表,只是获取结果集并写入 Excelsheet
错误日志如下
[7/21/16 2:46:43:455 EDT] 0007f794 SystemOut O 2016-07-21 02:46:43.455 [WARN] org.eclipse.persistence.session.podr02_user=PODRRPT.internalLog:588@PODRSchedWorkManager.Alarm Pool : 12 - Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.1.1.v20100817-r8050): org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: java.sql.SQLSyntaxErrorException: ORA-00942: table or view does not exist
Error Code: 942
Call: SELECT ROW, ABC, XYZ FROM VIRTUALTABLE WHERE (ROW = ?)
bind => [79]
Query: ReadObjectQuery(referenceClass=VirtualTable )
[7/21/16 2:46:43:455 EDT] 0007f794 SystemOut O 2016-07-21 02:46:43.455 [ERROR] com.bmo.cm.common.framework.service.AbstReportFileGenerator.generateReportFil e:88@PODRSchedWorkManager.Alarm Pool : 12 - Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.1.1.v20100817-r8050): org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: java.sql.SQLSyntaxErrorException: ORA-00942: table or view does not exist
Error Code: 942
Call: SELECT ROW, ABC, XYZ FROM VIRTUALTABLE WHERE (ROW = ?)
bind => [79]
Query: ReadObjectQuery(referenceClass=VirtualTable )
最佳答案
您不应该为此使用实体,因为实体需要 JPA 来管理和跟踪它们的更改,需要对象标识和缓存。相反,如果使用 JPA 2.1,您应该使用构造函数表达式来使用 ConstructorResult 构建 pojo在SqlResultSetMapping内
关于java - EclipseLink 在从 createNativeQuery 获取结果集之前随机触发查找查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38529607/
我有以下内容,其中包含一个 NativeQuery,我需要在其中设置参数,但有些事情是错误的,因为未设置参数,因此查询是 SELECT movieId, title, genres FROM movi
我有一个使用 EntityManager.createNativeQuery 的应用程序。我们的质量门(Sonar)对此不太满意,并且由于 SQL 注入(inject)的风险而向我显示了一个严重错误。
EntityManager em = OpenJPAUtils.openEntityManager(); String sql="select DISTINCT student.studentId f
如何使用 createNativeQuery 编写 IN 子句? 示例 codeList = "123 ,456"; 然后我得到这样的codeList: CODE IN (:codeList) 但是我
tl;博士 我有一个有效的 SQL 查询,它从 SQL 命令行返回行,但通过 Doctrine 提交时则不会。我认为问题在于我如何设置ResultSetMapper。我读过docs关于 native
我正在使用以下代码通过 hibernate 执行 native SQL 查询: Query zonesQuery = session.createNativeQuery( "S
我在我的项目中使用 Hibernate 和 JPA。我使用下面的代码返回对象列表,但当我在 mysql 中使用 sql 时它返回空列表,它工作正常。 Query query=entityManager
我在 Hibernate 中有一个简单的查找方法: @Override public TblUser findByUsername(String username) { return (Tbl
我正在尝试使用 createNativeQuery 从数据库获取结果集并将其映射到实体对象列表。 当我这样做的时候 List results = this.em.createNativeQuery(q
我需要使用entityManager选择 native 查询。我找到了方法: public Query createNativeQuery(String sqlString, Class result
我尝试使用 Doctrine 选择一百万行,但遇到了一些问题。 首先我尝试使用 ORM 查询来完成此操作,但后来我发现 native 查询更快。(我不需要为此使用 ORM 映射)。 我已经在使用数组水
我在数据库中加入了 2 个具有外键关系的实体,但在代码中没有(将原因留到另一个问题): em.createNativeQuery("SELECT u.* FROM user u JOIN user_c
我们最近将一个项目从使用 Hibernate 4 更新为 Hibernate 5.2,随之而来的是需要更新我们所有的标准以使用 JPA。大多数情况下一切正常,但我有一个查询不再运行。我们正在查询的表上
我想根据一个字段(类型)的值从两个不同的表中检索数据。基本上,如果类型是 2 或 3,则将“subcategory_id”分别关联到类别 2 或类别 3 普通 SQL: SELECT s.id, s.
在 PostgreSQL 数据库中执行的查询正在正确获取记录。但是,当使用 createnativeQuery 实现时,我收到错误 错误 SqlExceptionHelper:131 - 错误:“:”
我想在 entityManager 中使用 createNativeQuery 运行一个 Update 查询。我无法运行它。 我的类(class)结构: class ABC_DAO { List =
使用Java, hibernate 。 我有一个查询 String pixIds = "1,2,3"; String query = "SELECT * FROM comment WHERE PIX_
createNamedNativeQuery 和 createNativeQuery 之间是否有任何与性能相关的特性,因为我们计划对 HQL 查询使用命名查询,并为原生 SQL 查询维护单独的查询文件
EclipseLink 的奇怪行为(Eclipse Persistence Services - 2.1.1.v20100817-r8050),我有一个 false(虚拟/不是数据库中的实际表)实体类
乍一看我有一个简单的问题: entityManager() .createNativeQuery("select count(*) as total, select sum(field) as tot
我是一名优秀的程序员,十分优秀!