1

我想从 TypeCmplt 中提取所有数据,如下所示:

    public List<TypeCmplt> listerrTypeCmplt()
throws DaoException {
    Query query = cmpltTitreEM.createQuery("select t.cdTypeCmplt, t.lbTypeCmplt from TypeCmplt t");
    List<TypeCmplt> listeType = new ArrayList<TypeCmplt>();
    listeType = query.getResultList();
    return listeType;
}

测试方法:

    @Test
public void listerComplementsParTypeTest(){
    logger.debug("Afficher la liste des types de complémént") ;

    try {
        List<TypeCmplt> type = cmpltTitreDao.listerrTypeCmplt();
        for (int i = 0; i < type.size(); i++) {
            System.out.println(type.get(i));
        }

    } catch (DaoException e) {
        logger.error("Erreur", e) ;
    }

但我明白了:

Hibernate: select typecmplt0_.CD_TYPE_CMPLT as col_0_0_, typecmplt0_.LB_TYPE_CMPLT as col_1_0_ from TC_TYPE_CMPLT typecmplt0_
[Ljava.lang.Object;@4d2b11
[Ljava.lang.Object;@46a5c4
[Ljava.lang.Object;@2d09e0
[Ljava.lang.Object;@e38fca

有人可以帮忙吗?

4

2 回答 2

1

您正在尝试打印一个Object被调用的TypeCmplt. 尝试调用toString(). 正如@kostja 所说,您最好toString()TypeCmplt.

像这样:

System.out.println(type.get(i).toString());

或者:

TypeCmplt t = type.get(i);
System.out.println(t.getLong() + ": " + t.getString());

getLong()在这种情况下,您应该getString()相应地更换。

于 2013-04-24T08:31:33.863 回答
1

您正在为您的结果创建一个List<TypeCmplt>。但是结果列表是一个数组,Object因为您正在进行投影查询 - 提取TypeCmplt. 如果要TypeCmplt正确获取实体,请将查询字符串更改为

"select t from TypeCmplt t"

如果您确实想提取实体的多个属性,但要以类型安全的方式进行,那么构造函数表达式是可行的方法:

List<MyClass> dtos = cmpltTitreEM.createQuery("SELECT NEW com.example.MyClass( t.cdTypeCmplt, t.lbTypeCmplt) FROM TypeCmplt t").getResultList();
于 2013-04-24T08:42:35.890 回答