如何访问数据库OneToMany Hibernate并显示数据表?

时间:2014-12-19 08:58:48

标签: hibernate jsf

我在localhost FirebirdSQL上有一个数据库。我有两个类Empresa.java和LDIario.java它的OneToMany关系。我如何通过Empresa.java在xhtml中的新数据表中访问LDIario.java数据。我可以使用EmpresaDaoImpl sessionFactory.getCurrentSession()访​​问Empresa.java.createQuery(“来自Empresa”)。list();但我不知道在LDiarioDAOImpl sessionFactory.getCurrentSession()。createQuery(“来自LDiario”)中是否可以.list();对不起我在学英语。非常感谢你。 ------ Empresa与GT&; LDiario

Empresa.java

@Entity
@Table(name = "empresas")
public class Empresa implements Serializable{

@Id 
@Column(name = "CLAVE")
@GeneratedValue private Integer CLAVE;

@OneToMany
@JoinColumn(name = "empresa")  
private List<LDiario> ldiarios; 

LDiario.java

@Entity
@Table(name = "LDIARIO2014")
public class LDiario implements Serializable{

@Id 
@Column(name = "CLAVE")
@GeneratedValue private Integer CLAVE;  

@ManyToOne  
@JoinColumn (name = "empresa") 
private Empresa empresa;

EmpresaBean.java

@ManagedBean(name="empresaBean")
@ViewScoped
@Component
public class EmpresaBean {

    @Autowired
    private EmpresaService empresaService;
    private Empresa empresa;
    private Empresa selectedEmpresa;


    public EmpresaService getEmpresaService() {
        return empresaService;
    }

    public Empresa getSelectedEmpresa() {
        return selectedEmpresa;
    }

    public void setSelectedEmpresa(Empresa selectedEmpresa) {
        this.selectedEmpresa = selectedEmpresa;
    }

    public void setEmpresaService(EmpresaService empresaService) {
        this.empresaService = empresaService;
    }

    public EmpresaBean(){
    }

    public List<Empresa> getEmpresaList(){

        return empresaService.getAll();
    }

    public Empresa getEmpresa() {
        return empresa;
    }
    public void setEmpresa(Empresa empresa) {
        this.empresa = empresa;
    }  

    public String View() {

        return "/pages/menu/menuPrincipal?faces-redirect=true";
    }
}

LDiarioBean.java

@ManagedBean(name="ldiarioBean")
@ViewScoped
@Component
public class LDiarioBean {

    private LDiario ldiario;
    @Autowired
    private LDiarioService ldiarioservice;

    private LDiario selectedLdiario;

    public LDiarioService getLdiarioservice() {
        return ldiarioservice;
    }
    public void setLDiarioservice(LDiarioService ldiarioservice) {
        this.ldiarioservice = ldiarioservice;
    }

    public LDiarioBean(){

    }
    public LDiario getLdiario() {
        return ldiario;
    }
    public void setLdiario(LDiario ldiario) {
        this.ldiario = ldiario;
    } 
    public LDiario getSelectedLdiario() {
        return selectedLdiario;
    }
    public void setSelectedLdiario(LDiario selectedLdiario) {
        this.selectedLdiario = selectedLdiario;
    }    

    public List<LDiario> getLDiarioList(){  
        return ldiarioservice.getAll();
    }

    public LDiario getLDiario() {
        return ldiario;
    }
    public void setLDiario(LDiario ldiario) {
        this.ldiario = ldiario;
    } 
}

LDiarioDAOImpl.java

@Transactional
@Repository
public class LDiarioDaoImpl implements LDiarioDao{

    @Autowired
    private SessionFactory sessionFactory;

    @Override
    public List<LDiario> findAll() {
        return sessionFactory.getCurrentSession().createQuery("from LDiario").list();
    }
}

EmpresaDAOImpl.java

@Transactional
@Repository
public class EmpresaDaoImpl implements EmpresaDao{

    @Autowired
    private SessionFactory sessionFactory;

    @Override
    public List<Empresa> findAll() {
        return sessionFactory.getCurrentSession().createQuery("from Empresa").list();
    }
}

的index.xhtml

   <h:head>
      <title>Lista con Java Server Faces</title>
   </h:head>
   <h:body> 

      <h:form id="form">
    <p:dataTable id="radioDT"  var="emp" value="#{empresaBean.getEmpresaList()}"  
                selection="#{empresaBean.selectedEmpresa}" rowKey="#{emp.CLAVE}">



    <f:facet name="header">
            Lista de Empresas
         </f:facet>
         <p:column selectionMode="single" style="width:16px;text-align:center"/>         
      <p:column headerText="Id">
       <h:outputText value="#{emp.CLAVE}" />
       </p:column>

         <p:column headerText="Nombre Empresa">
       <h:outputText value="#{emp.NOMBRE}" />
       </p:column>

         <p:column headerText="AÑO">
       <h:outputText value="#{emp.EJERCICIO}" />
       </p:column>

       <!-- "#{empresaBean.selectedEmpresa}" -->
<f:facet name="footer">

    <p:commandButton action="#{empresaBean.View}" value="Seleccionar" title="Ir Menu" rowKey="#{emp.CLAVE}" >
 <f:setPropertyActionListener target="#{empresaBean.empresa}" value="#{empresaBean.selectedEmpresa}" />
</p:commandButton>

menuPrincipal.xhtml (此页面中的错误)

<h:form>
    <!--   <h:outputText value="#{empresaBean.empresa}" />  -->

    <h:outputText value="#{empresaBean.selectedEmpresa}" /> 

        <p:dataTable   var="ld" value="#{empresaBean.empresa.ldiarios}">
    <!-- selection="#{ldiarioBean.selectedLdiario}" rowKey="#{ld.CLAVE}" -->

    <f:facet name="header">
        Listado Diario
     </f:facet>
     <p:column selectionMode="single" style="width:16px;text-align:center"/>         
  <p:column headerText="ASIENTO">
   <h:outputText value="#{ld.ASIENTO}" />
   </p:column>

好的empresaBean.empresa.ldiarios?你会写什么? THX。

0 个答案:

没有答案