你好我是新手休眠,我試圖訪問數據沒有成功:(我試了一個月,我有兩個表,第一個Empresa和第二個LDiario。我可以看到數據Empresa與我們,但是當我選擇一個單選按鈕訪問下一個表(LDiario)我看到了虛空如何使用hibernate訪問oneToMany數據? (休眠+彈簧+ Primefaces)
一對多Empresa與 - > LDIario 多對一LDIario - > Empresa與
我使用Primefaces。對不起,我的英語,我正在學習它
UPDATE我已經完成LDiario,Empresa的更新,我添加了Empr esaBean
EmpresaDaoImpl
@Transactional
@Named
public class EmpresaDaoImpl implements EmpresaDao{
@Inject
private SessionFactory sessionFactory;
@Override
public List<Empresa> findAll() {
return sessionFactory.getCurrentSession().createQuery("from Empresa").list();
}
}
LDiarioImpl
@Transactional
@Named
public class LDiarioDaoImpl implements LDiarioDao{
@Inject
private SessionFactory sessionFactory;
@Override
public List<LDiario> findAll() {
return sessionFactory.getCurrentSession().createQuery("from LDiario").list();
}
}
Empresa與UPDATE
@Entity
@Table(name = "empresas")
public class Empresa implements Serializable{
@Id
@Column(name = "CLAVE")
@GeneratedValue private Integer CLAVE;
@OneToMany(mappedBy = "empresa")
private List<LDiario> ldiarios;
LDiario
@Entity
@Table(name = "LDIARIO2014")
public class LDiario implements Serializable{
@Id
@Column(name = "CLAVE")
@GeneratedValue private Integer CLAVE;
@ManyToOne
@JoinColumn (name = "empresa_id")
private Empresa empresa;
查看Empresa與(Primeface)它的工作原理。
<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"
> LDiario查看(不工務)
<p:dataTable var="ld" value="#{empresaBean.ldiario}" rowKey="#{ld.CLAVE}">
<!-- 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>
<p:column headerText="FECHA">
<h:outputText value="#{ld.FECHA}" />
</p:column>
<p:column headerText="SUBCUENTA">
<h:outputText value="#{ld.SUBCUENTA}" />
</p:column>
<p:column headerText="CONCEPTO">
<h:outputText value="#{ld.CONCEPTO}" />
</p:column>
我不知道,如果問題是EmpresaDaoService或其他。我不知道這部分寫的是什麼。
LDiario查看
<p:dataTable var="ld" value="#{empresaBean.ldiario}" rowKey="#{ld.CLAVE}">
THX非常多。
EmpresaBean
@ManagedBean(name="empresaBean")
@ViewScoped
@Named
public class EmpresaBean {
@Inject
private EmpresaService empresaService;
private Empresa empresa;
private Empresa selectedEmpresa;
private LDiario ldiario;
public LDiario getLdiario() {
return ldiario;
}
public void setLdiario(LDiario ldiario) {
this.ldiario = ldiario;
}
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";
}
}
i'm使用DBVisualizer中,因爲數據庫是其他軟件和我不明白每個表。
PKTABLE_NAME EMPRESAS LDIARIO2014
PKCOLUMN_NAME CLAVE CLAVE
FK_NAME INTEG_651
PK_NAME INTEG_39
UPDATE 2我增加了兩個新的圖像。我認爲這個錯誤是你在empresa_id中說的,但我知道我必須在那裏寫。
LDiarioBean
@ManagedBean(name="ldiarioBean")
@ViewScoped
@Named
public class LDiarioBean {
private LDiario ldiario;
@Inject
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
@Transactional
@Named
public class LDiarioDaoImpl implements LDiarioDao{
@Inject
private SessionFactory sessionFactory;
@Override
public List<LDiario> findAll() {
return sessionFactory.getCurrentSession().createQuery("from LDiario").list();
}
}
我想前幾天,但我有一個問題與LDIARIO和我認爲我不能同時帶來所有數據,因爲我認爲該表是動態的。謝謝。 – ProSyth