我在使用具有复合主键的多重选择(复选框)的primefaces数据表时遇到问题 下面是我的xhtml
<p:dataTable id="cars" var="car" value="#{setujutolakanpencairan.listmktksppencairan0}"
rowKey="#{car.mktksppencairan0PK}"
selection="#{setujutolakanpencairan.mktksppencairan0s}" >
<p:ajax event="rowSelectCheckbox" process="@this"/>
<p:column selectionMode="multiple" style="width:2%" />
<f:facet name="header">
Click "View" button after selecting multiple to see details
</f:facet>
<p:column headerText="Color">
#{car.vcKeterangan}
</p:column>
<f:facet name="footer">
<p:commandButton value="View" icon="ui-icon-search"
update=":form:display" oncomplete="carDialog.show()" actionListener="#{setujutolakanpencairan.outprint()}"/>
</f:facet>
</p:dataTable>
下面是我的背豆
private List<Mktksppencairan0> listmktksppencairan0;
private Mktksppencairan0[] mktksppencairan0s;
下面是我的getter setter
public Mktksppencairan0[] getMktksppencairan0s() {
if (mktksppencairan0s != null) {
for (Object asdf : mktksppencairan0s) {
System.out.println("mktksppencairan0s mktksppencairan0s mktksppencairan0smktksppencairan0s =====" + asdf);
}
}
return mktksppencairan0s;
}
public void setMktksppencairan0s(Mktksppencairan0[] mktksppencairan0s) {
this.mktksppencairan0s = mktksppencairan0s;
}
下面是显示数据的列表
public List<Mktksppencairan0> getListmktksppencairan0() {
TypedQuery<Mktksppencairan0> query = em.createNamedQuery("Mktksppencairan0.findBybulantahun", Mktksppencairan0.class);
query.setParameter(
"iTahun", mktkontrol.getTahun());
query.setParameter(
"iBulan", mktkontrol.getBulan());
List<Mktksppencairan0> results = query.getResultList();
return results;
}
public void setListmktksppencairan0(List<Mktksppencairan0> listmktksppencairan0) {
this.listmktksppencairan0 = listmktksppencairan0;
}
这是我用来调试值
的动作 public void outprint() {
System.out.println("asdfasdf ===" + mktksppencairan0s.toString().length());
System.out.println("asdfasdf ===" + mktksppencairan0s.toString());
System.out.println("asdfasdf ===" + mktksppencairan0s);
for (Mktksppencairan0 asdf : mktksppencairan0s) {
System.out.println("mktksppencairan0s mktksppencairan0s mktksppencairan0smktksppencairan0s =====" + asdf.toString().length());
}
}
当我使用netbeans调试器进行调试时,它是result []或0 当我System.out它结果
INFO: asdfasdf ===[Lcom.infion.web.biaya_marketing.entity.Mktksppencairan0;@a20a9b
INFO: asdfasdf ===64
INFO: asdfasdf ===[Lcom.infion.web.biaya_marketing.entity.Mktksppencairan0;@1f5db6
INFO: asdfasdf ===[Lcom.infion.web.biaya_marketing.entity.Mktksppencairan0;@1f5db6
仅供参考我使用netbeans 7.3,glassfish 3.1.2,primefaces 3.5 *我使用的实体是由netbean生成的,所以有两类实体Mktksppencairan0PK和Mktksppencairan0,其中Mktksppencairan0嵌入了Mktksppencairan0PK 谢谢你的帮助
注意:我已尝试使用非复合主键(单主键)及其工作原理,但当我尝试使用其他复合主键时,它无法正常工作
答案 0 :(得分:0)
我遇到了同样的问题,但我一如既往地使用实体列表。
private List<SipreTmpGuardia> beanList;
private List<SipreTmpGuardia> beanListSelected;
然后我用selectionmode multiple设置我的数据表:
<!-- DATATABLE-->
<p:dataTable id="dt" var="item" widgetVar="wdt"
rowIndexVar="rowIndex"
value="#{guardia.beanList}"
emptyMessage="#{constantesUtil.LIST_EMPTY}" paginator="true"
rows="20" paginatorPosition="top"
paginatorTemplate="{CurrentPageReport} {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} "
selection="#{guardia.beanListSelected}" rowKey="#{item.codigoRowIndexTemp}"
>
<p:column headerText="N*" width="1%">
<h:outputText value="#{rowIndex+1}" />
</p:column>
<p:column selectionMode="multiple" width="1%"/>
<p:column headerText="Indicador Mes o Reintegro" width="2%">
<h:outputText value="#{item.ctgIndSituacion==2?'Reintegro':'Proceso Mes'}" />
</p:column>
<f:facet name="footer">
<p:commandButton ajax="false" action="#{guardia.saveListTmpGuardia()}" update=":frm:messages,:frm:dt,:frm:dtGM" icon="ui-icon-search" value="Guardar Seleccionados" />
</f:facet>
</p:dataTable>
编辑: 据我所知,primefaces 5中的RowKey不支持复合主键。 我上面做的是设置rowKey =“#{item.codigoRowIndexTemp}”并在填充我的表的函数中填充它.. value =“#{guardia.beanList}”。
不需要设置复合主键只需在实体中创建一个临时属性,如“codigoRowIndexTemp”,然后填充它。 当您选择它时,它将通过您的codigoRowIndexTemp过滤您的列表。
试试吧!
BTW1: 我的复合主键或EmbeddedId是:
@EmbeddedId
protected SipreTmpGuardiaPK sipreTmpGuardiaPK;
答案 1 :(得分:0)
您需要将selectionMode设置为“multiple”,并提及@dmatos,并且rowkey必须返回每行的唯一标识符,并且需要保持一致。如果它变得更复杂,那么你总是可以在primefaces中实现selectabledatamodel,然后访问rowKey中的唯一字段。