那么问题标题说,我试图做一个投影标准只查询表的几个属性。休眠标准投影
所以我有一个Person Table /类,它有大约40个属性。我希望我的标准来获得属性的动态数量,可以说,10,11或12(SQL方面select firstname, lastname from person
),我在做这样的:
Transaction tx = session.beginTransaction();
Criteria crit = session.createCriteria(Person.class);
crit.setCacheable(true);
ProjectionList projList = Projections.projectionList();
projList.add(Projections.property("id"));
Criterias c = null;
for (int i = 0; i < checked.size(); i++) {
Attribute attr = checked.elementAt(i);
switch (attr) {
case LASTNAME:
projList.add(Projections.property("lastName"));
c = enumMap.get(attr);
if (c.isChanged()) {
String tmp = (String) c.getAnswer();
tmp = tmp.replace('*', '%');
crit.add(Restrictions.like("lastName", tmp));
crit.addOrder(Order.asc("lastName"));
}
case ...THE REST .....
}
crit.setProjection(projList);
retList = crit.list();
tx.commit();
return retList;
而且还给了retList
元素不是从Person.class
:
INFO [AWT-EventQueue的-0](UserGroupManagerApp.java127) - [Ljava.lang.Object; @ 14b9b80
致命[AWT-EventQueue的-0](Login.java78) - java.lang中.ClassCastException:[Ljava.lang.Object;无法转换为usergroupmanager.model.db.Person java.lang.ClassCastException:[Ljava.lang.Object;不能投到usergroupmanager.model.db.Person
请帮忙,现在我列出所有40+ attr,它占用了查询时间,我不喜欢它。我正在寻找替代解决方案,这将帮助我解决这个问题。我读了约ResultTransformer
,但没有找到如何使用它在我的情况。
什么是retList的定义 – Mark 2010-09-11 13:29:30
List retList = null;在开始时,我测试了它与泛型现在列表 retList = null和相同的东西 –
Darwly
2010-09-11 13:33:44