2013-05-07 37 views
1

我得到了迭代从HQL准备好的List的问题。 我在查询映射到非常简单的类的单个表上的数据库。类型转换后即使ClassCastException

在迭代期间迭代相同的列表和类型转换为相同的类后,我得到ClassCastException。

代码:

import HectorRequest; 
import EDIMigrateData; 

SessionFactory factory = HibernateUtil.getSessionFactory(); 
Session session = factory.getCurrentSession(); 
Transaction tx = session.beginTransaction(); 
Query qry = session.createQuery("select hr from HectorRequest hr"); 

List result = qry.list(); 
for (Iterator it = result.iterator(); it.hasNext();) { 
    Object o = it.next(); 
    if(o instanceof HectorRequest){ 
     HectorRequest h = (HectorRequest) o; 
     System.out.println("ID: " + h.getId()); 
    } 
} 

我想在这里如果我对类型转换是给ClassCastException异常同一类。

if(o instanceof HectorRequest) { 
    HectorRequest h = (HectorRequest) o; 
    System.out.println("ID: " + h.getId()); 
} 

控件没有进入上面的if语句。 如果删除上述IF条件它是扔

java.lang.ClassCastException: HectorRequest 

下面是HectorRequest类我的Hibernate映射XML。

下面是我的hibernate.cfg.xml

?xml version="1.0" encoding="utf-8"?><!DOCTYPE hibernate-configuration PUBLIC"-//Hibernate/Hibernate Configuration DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"><hibernate-configuration><session-factory><property name="hibernate.connection.driver_class">oracle.jdbc.driver.OracleDriver</property><property name="hibernate.connection.url">jdbc:oracle:thin:@//apludc01clu20-scan-oravip.dci.bt.com:61901/C2BM2_ANY</property><property name="hibernate.connection.username">s3</property><property name="hibernate.connection.password">**</property><property name="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</property><property name="hibernate.default_schema">s3</property><property name="show_sql">true</property><property name="hibernate.current_session_context_class">thread</property><mapping resource="resources/config/hector_request.hbm.xml"></mapping></session-factory></hibernate-configuration> 

下面是输出:

Hibernate: select hectorrequ0_.ID as ID0_, hectorrequ0_.ROUTER_TEL as ROUTER2_0_, hectorrequ0_.FLAGVALUE as FLAGVALUE0_, hectorrequ0_.FLAGPOS as FLAGPOS0_, hectorrequ0_.ACCOUNTNO as ACCOUNTNO0_, hectorrequ0_.CUSTOMERIDENTITY as CUSTOMER6_0_, hectorrequ0_.CRMSOURCE as CRMSOURCE0_, hectorrequ0_.DATASOURCE as DATASOURCE0_ from s3.hector_request hectorrequ0_ 

java.lang.ClassCastException: HectorRequest 

at NotifyMain1.main(NotifyMain1.java:37) 

有人能帮助什么人失踪,错在这里。

回答

0

这是因为查询返回的数据“从HectorRequest hr选择hr”不是“HectorRequest”。它可能是一个数据库数据类型(字符串,数字,日期,时间等)。所以你必须使用查询返回的数据来构建你的“HectorRequest”对象,而不是直接使用转换赋值给它。