如何在dataTable中显示数据库中的数据?

时间:2017-01-27 18:32:16

标签: java jsf datatable

在我的java web项目中,我想测试如何在dataTable中显示列表,我有一个示例,其中显示了该列表。我尝试按照示例进行操作,因此我创建了一个新的xhtml页面,其中我复制了样本的dataTable,我添加了一个新的dataTable,并创建了一个名为StatPanne的新bean。示例的bean是NaturePanneController。 问题是新的dataTable是空的。我知道新bean返回的列表是空的,但我不知道为什么,请你帮助我。谢谢。

@Name("naturePanneController")
@Scope(ScopeType.CONVERSATION)
public class NaturePanneController {
@In
EntityManager entityManager;
@In
@Out
NaturePanne naturePanne;

private Boolean edit = false;
private Integer paramid;

public Boolean getEdit() {
    return edit;
}

public Integer getParamid() {
    return paramid;
}

public void setParamid(Integer paramid) {
    this.paramid = paramid;
}

public void setEdit(Boolean edit) {
    this.edit = edit;
}

public List<NaturePanne> getNaturePanne() {
return entityManager.createQuery("select a from NaturePanne a")
            .getResultList();   
}


public void selectNP(NaturePanne np) {
    naturePanne = np;

}

public void supprimer() {
    if (naturePanne != null) {
        //if (nn != null) {
        Integer a = getParamid();
        NaturePanne np = entityManager.find(NaturePanne.class, a);
        entityManager.remove(np);
    }
}

public void ajouter(ActionEvent e) {
    entityManager.persist(naturePanne);
    naturePanne = new NaturePanne();
}


public void mettreajour() {

    if (getEdit() == true) {
        setEdit(false);
    } else {
        setEdit(true);
    }}}

我的新bean StatPanne.java

@Name("statPanne")
@Scope(ScopeType.CONVERSATION)
public class StatPanne {
@In
EntityManager entityManager;

@In
@Out
NaturePanne naturePanne;


private Boolean edit = false;
private Integer paramid;



public Boolean getEdit() {
    return edit;
}

public Integer getParamid() {
    return paramid;
}

public void setParamid(Integer paramid) {
    this.paramid = paramid;
}

public void setEdit(Boolean edit) {
    this.edit = edit;
}

 public List<NaturePanne> getNaturePanne() {
    return entityManager.createQuery("select a from NaturePanne a").getResultList();


}


public void selectNP(NaturePanne np) {
    naturePanne = np;
}

public void supprimer() {
if (naturePanne != null) {
    //if (nn != null) {
    Integer a = getParamid();
    NaturePanne np = entityManager.find(NaturePanne.class, a);
    entityManager.remove(np);
}
}

public void ajouter(ActionEvent e) {
entityManager.persist(naturePanne);
naturePanne = new NaturePanne();
}


 public void mettreajour() {

if (getEdit() == true) {
    setEdit(false);
} else {
    setEdit(true);}}}

我的页面xhtml包含两个数据表

<!-- the new dataTable: empty table -->
<h:form>
<rich:dataTable   value="#{statPanne.naturePanne}" var="lp">
<h:column headerClass="headerleftfacet">
<f:facet name="header">
<h:outputText value="#{msg.nom_panne}" />
</f:facet> 
<h:outputText id="outtt" value="#{lp.lib_naturepanne}"/>      
</h:column>
</rich:dataTable>
</h:form>       


<!-- the old dataTable:works well -->
<h:form>
<rich:dataTable  var="panne" value="#{naturePanneController.naturePanne}">
<h:column headerClass="headerleftfacet">
<f:facet name="header">
<h:outputText value="#{msg.nom_panne}" />
</f:facet>
<h:outputText  value="#{panne.lib_naturepanne}"/>
</h:column>
</rich:dataTable>
</h:form>

实体NaturePanne.java

@Entity
@Name("naturePanne")
@Scope(ScopeType.EVENT)
@AutoCreate
@Table(name = "naturepanne")
public class NaturePanne implements Serializable {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Integer id_naturepanne;
private String lib_naturepanne;

//Getters/Setters

1 个答案:

答案 0 :(得分:0)

检查EntityManager配置。 在EMF设置中启用show sql config,如下所示。

取决于您使用的实施方式.. 对于休眠:
<property name = "hibernate.show_sql" value = "true" /> 对于jpa: <property name="${filename}" value="DefaultLevel=WARN, Runtime=INFO, Tool=INFO, SQL=TRACE"/>

这样,您可以看到它尝试执行的SQL,您可以单独测试此SQL,看看您是否确实从数据存储中获得了结果。