0

我对项目中的查看数据有小问题h:dataTable。我有在数据库和java中正常工作的本机查询:

SELECT SUM(price_list.first_class_price), SUM(price_list.second_class_price)
FROM price_list, connections
WHERE connections.id = price_list.id_connect
GROUP BY connections.source;  

EJB 中的方法返回一个元素列表。此方法如下所示:

public List<PriceList> getFirstClassPrices() { 
    Query q = em.createNativeQuery("SELECT SUM(price_list.first_class_price), SUM(price_list.second_class_price) FROM price_list, connections WHERE connections.id = price_list.id_connect GROUP BY connections.source"); 
    return q.getResultList(); 
}  

我想在 dataTableItem 中显示此查询的结果,但我不知道如何获取此值。我试图做这样的事情(FCP 是 JSF ManagedBean 中返回提到列表的方法):

<h:dataTable value="#{priceList.FCP}}" var="item" cellspacing="0" cellpadding="1" border="1"> 
<h:column> 
<f:facet name="header"> 
<h: outputText value="First class"/> 
</f:facet> 
<h: outputText value="#{item}"/> 
</h:column> 
<h:column> 
<f:facet name="header"> 
<h: outputText value="Second class"/> 
</f:facet> 
<h: outputText value="#{item}"/> 
</h:column> 
</h:dataTable> 

但这仅向我显示了表中结果的引用。

JSF ManagedBean 中的 FCP 方法如下所示:

public List<PriceList> getFCP() { 
    return priceListFacade.getFirstClassPrices(); 
} 

当我有这样的查询时,此解决方案可以正常工作:

SELECT SUM(price_list.first_class_price) 
FROM price_list, connections 
WHERE connections.id = price_list.id_connect
GROUP BY connections.source;

带有一个 SUM 元素。然后正确的数据在表中,没有问题。

我的问题是:当我在查询中有两个或多个 SUM 元素时,如何获取数据,结果列表中没有引用?

我尝试使用这样的代码:

<h:dataTable value="#{priceList.FCP}}" var="item" cellspacing="0" cellpadding="1" border="1"> 
<h:column> 
<f:facet name="header"> 
<h: outputText value="First class"/> 
</f:facet> 
<h: outputText value="#{item.first_class_price}"/> 
</h:column> 
<h:column> 
<f:facet name="header"> 
<h: outputText value="Second class"/> 
</f:facet> 
<h: outputText value="#{item.second_class_price}"/> 
</h:column> 
</h:dataTable> 

但后来我有一个 EJB 异常:没有像first_class_priceand之类的属性second_class_price

我试图为此更改查询:

SELECT SUM(price_list.first_class_price) AS p1, SUM(price_list.second_class_price) AS p2 
FROM price_list, connections 
WHERE connections.id = price_list.id_connect
GROUP BY connections.source; 

然后在JSF中我使用了这样的代码:

<h:dataTable value="#{priceList.FCP}}" var="item" cellspacing="0" cellpadding="1" border="1"> 
<h:column> 
<f:facet name="header"> 
<h: outputText value="First class"/> 
</f:facet> 
<h: outputText value="#{item.p1}"/> 
</h:column> 
<h:column> 
<f:facet name="header"> 
<h: outputText value="Second class"/> 
</f:facet> 
<h: outputText value="#{item.p2}"/> 
</h:column> 
</h:dataTable> 

但我有相同的 EJB 异常,即属性 p1 和 p2 不存在。

我是 Java EE 的新手,我无法处理这个问题。也许还有另一种方法可以解决我的问题?也许我不应该使用h:dataTableItem

感谢您的回复。

4

2 回答 2

0

我在另一个主题上找到了我的问题的解决方案。这是正确的解决方案:

会话豆:

public List<Object[]> getFirstClassPrices() {
    Query q = em.createNativeQuery("SELECT SUM(price_list.first_class_price), "
            + "SUM(price_list.second_class_price), SUM(price_list.third_class_price), "
            + "SUM(price_list.luggage_fee), SUM(price_list.airport_fee), SUM(price_list.fuel_fee), "
            + "SUM(price_list.crew_salary), connections.source FROM price_list, connections WHERE connections.id = price_list.id_connect GROUP BY connections.source");
    List<Object[]> lista = q.getResultList();
    return lista;
}

JSF ManagedBean:

public List<Object[]> getFCP() {   
    return priceListFacade.getFirstClassPrices();
}

最后是 JSF 页面的片段:

<h:outputText value="#{item[0]}"/>
于 2010-08-13T13:15:24.863 回答
0

尝试在我的应用程序中使用“GROUP BY”查询时卡住了。我使用的解决方案如下:

1、tableNamefacade.java:

public List<Object[]> getAllGroupByCoulumn() {
  Query q = em.createNativeQuery("SELECT d.column FROM tableName d GROUP BY d.coulmn");
  List<Object[]> list = q.getResultList();
  return list;
}

2、tableNameController.java: bean的属性:

private List<Object[]> items;

和函数,它准备在 xhtml 页面上显示的列表:

items = getFacade().getAllGroupByCoulumnm();

3、finaly xhtml页面中的dataTable :

<h:dataTable value="#{myController.items}" var="item">
  ...
     <h:outputText value="#{item}">
  ...

于 2012-03-14T15:40:30.753 回答