使用Hibernate,Primefaces和Spring更新记录

时间:2012-08-22 06:11:58

标签: java spring hibernate java-ee primefaces

我正在使用spring 3 hibernate 4 jsfprimefaces的集成。 在我的数据表中我可以insertdelete一条记录,但我的更新代码不起作用,无法更新表和数据库。我不想使用primefaces cell editor,我希望command button执行更新。但是当我单击命令按钮时,它会删除数据库和数据表中除了personel_id字段之外的单元格(字段)。请帮我正确的代码。 enter image description here 当我编辑字段并单击更新按钮时: enter image description here personelDao.java

public class PersonelDao implements IPersonelDao {
    private SessionFactory sessionFactory;
    public void addPersonel(Personel personel) {
        getSessionFactory().getCurrentSession().save(personel);
    }
    public Personel updatePersonel(Personel personel) {

final Session session = getSessionFactory().getCurrentSession();
if(session.contains(personel)){
    session.update(personel);
} else {
    personel = (Personel) session.merge(personel);
}
return personel;
}
public void deletePersonel(Personel personel) {
            getSessionFactory().getCurrentSession().delete(personel);
        }
    }

personelservice.java

@Transactional(readOnly=true)
public class PersonelService implements IPersonelService{
    IPersonelDao personeldao;
    @Transactional(readOnly=false)
    public void addPersonel(Personel personel) {
        getPersoneldao().addPersonel(personel);
    }

    @Transactional(readOnly=false)
    public void updatePersonel(Personel personel){
        getPersoneldao().updatePersonel(personel);
    }
    @Transactional(readOnly=false)
    public void deletePersonel(Personel personel) {
        getPersoneldao().deletePersonel(personel);
    }
}

personelbean.java

@ManagedBean(name="personelMB")
@RequestScoped
public class PersonelBean implements Serializable{
    private static final long serialVersionUID = 1L;
    @ManagedProperty(value="#{PersonelService}")
    IPersonelService personelservice;
    List<Personel> personelList;
    private int personel_id;
    private String pname;
    private String pfamily;
    private String paddress;
    private String pphone;

    //getter and setter
    public void addPersonel(){
            Personel personel=new Personel();
            personel.setPaddress(getPaddress());
            personel.setPersonel_id(getPersonel_id());
            personel.setPfamily(getPfamily());
            personel.setPname(getPname());
            personel.setPphone(getPphone());
            getPersonelservice().addPersonel(personel);
            reset();
    }

    public void deletePersonel(int personel_id){
            Personel personel=(Personel)personelservice.getPersonelId(personel_id);
            getPersonelservice().deletePersonel(personel);
    }

    public void update(int personel_id){
        Personel personel=(Personel)personelservice.getPersonelId(personel_id);
        personel.setPaddress(getPaddress());
        personel.setPfamily(getPfamily());
        personel.setPname(getPname());
        personel.setPphone(getPphone());
        getPersonelservice().updatePersonel(personel);
    }
}

personel.xhtml

    <h2>مشاهده اطلاعات پرسنل</h2>   
     <h:form  prependId="false">  
      <p:dataTable id="pdataTable" var="personel" value="#{personelMB.personelList}" rowKey="#{personelMB.personel_id}" editable="true"
         >  
            <f:facet name="header">  
                اطلاعات پرسنل 
            </f:facet>  
              <p:column> 
             <f:facet name="header">  
                   شماره پرسنلی  
                </f:facet>  
                <h:outputText value="#{personel.personel_id}" />  
                <f:facet name="footer">  
                    کدملی 
                </f:facet>  
            </p:column>  
      <p:column headerText="نام">
            <p:inputText value="#{personel.pname}" size="5"/>
                 </p:column>  
      <p:column headerText="نام خانوادگی"> 
             <p:inputText value="#{personel.pfamily}" size="5"/>
                </p:column>  
      <p:column headerText="آدرس"> 
            <p:inputText value="#{personel.paddress}" size="5"/>
            </p:column>  
       <p:column headerText="تلفن"> 
                <p:inputText value="#{personel.pphone}" size="5"/> 
            </p:column>
            <p:column headerText="حذف">
          <f:facet name="حذف">
             <h:outputText value="" />
          </f:facet>
          <p:commandButton icon="ui-icon-trash" title="حذف"
                           actionListener="#{personelMB.deletePersonel(personel.personel_id)}"  update="@form" ajax="true"/>
       </p:column>
       <p:column headerText="ويرايش">
      <p:commandButton icon="ui-icon-pencil" title="ويرایش"
                           actionListener="#{personelMB.update(personel.personel_id)}"  update="@form" ajax="true"/>
</p:column>
        <f:facet name="footer">  
            تعداد رکورد#{fn:length(personelMB.getPersonelList())} میباشد.  
        </f:facet>  

    </p:dataTable> 

personel.java

@Entity
@Table(name="TBLPERSONEL")
public class Personel {
    @Id
    @Column(name="PERSONEL_ID")
    private int personel_id;
    @Column(name="PNAME")
    private String pname;
    @Column(name="PFAMILY")
    private String pfamily;
    @Column(name="PADDRESS")
    private String paddress;
    @Column(name="PPHONE")
    private String pphone;
    @OneToOne
    @PrimaryKeyJoinColumn
    private Manager manager;
    @OneToMany(mappedBy="personel")
    private Set<Stufftransfer> stufftransfers;
    public Personel(){

    }
    //getter and setter
}

追踪:

Hibernate: update TBLPERSONEL set PADDRESS=?, PFAMILY=?, PNAME=?, PPHONE=? where PERSONEL_ID=?
Hibernate: select personel0_.PERSONEL_ID as PERSONEL1_1_, personel0_.PADDRESS as PADDRESS1_, personel0_.PFAMILY as PFAMILY1_, personel0_.PNAME as PNAME1_, personel0_.PPHONE as PPHONE1_ from TBLPERSONEL personel0_
Hibernate: select manager0_.ID as ID0_1_, manager0_.PASSWORD as PASSWORD0_1_, manager0_.PERSONEL_ID as PERSONEL3_0_1_, personel1_.PERSONEL_ID as PERSONEL1_1_0_, personel1_.PADDRESS as PADDRESS1_0_, personel1_.PFAMILY as PFAMILY1_0_, personel1_.PNAME as PNAME1_0_, personel1_.PPHONE as PPHONE1_0_ from TBLMANAGER manager0_ left outer join TBLPERSONEL personel1_ on manager0_.ID=personel1_.PERSONEL_ID where manager0_.ID=?
Hibernate: select manager0_.ID as ID0_1_, manager0_.PASSWORD as PASSWORD0_1_, manager0_.PERSONEL_ID as PERSONEL3_0_1_, personel1_.PERSONEL_ID as PERSONEL1_1_0_, personel1_.PADDRESS as PADDRESS1_0_, personel1_.PFAMILY as PFAMILY1_0_, personel1_.PNAME as PNAME1_0_, personel1_.PPHONE as PPHONE1_0_ from TBLMANAGER manager0_ left outer join TBLPERSONEL personel1_ on manager0_.ID=personel1_.PERSONEL_ID where manager0_.ID=?
Hibernate: select manager0_.ID as ID0_1_, manager0_.PASSWORD as PASSWORD0_1_, manager0_.PERSONEL_ID as PERSONEL3_0_1_, personel1_.PERSONEL_ID as PERSONEL1_1_0_, personel1_.PADDRESS as PADDRESS1_0_, personel1_.PFAMILY as PFAMILY1_0_, personel1_.PNAME as PNAME1_0_, personel1_.PPHONE as PPHONE1_0_ from TBLMANAGER manager0_ left outer join TBLPERSONEL personel1_ on manager0_.ID=personel1_.PERSONEL_ID where manager0_.ID=?
Hibernate: select personel0_.PERSONEL_ID as PERSONEL1_1_, personel0_.PADDRESS as PADDRESS1_, personel0_.PFAMILY as PFAMILY1_, personel0_.PNAME as PNAME1_, personel0_.PPHONE as PPHONE1_ from TBLPERSONEL personel0_
Hibernate: select manager0_.ID as ID0_1_, manager0_.PASSWORD as PASSWORD0_1_, manager0_.PERSONEL_ID as PERSONEL3_0_1_, personel1_.PERSONEL_ID as PERSONEL1_1_0_, personel1_.PADDRESS as PADDRESS1_0_, personel1_.PFAMILY as PFAMILY1_0_, personel1_.PNAME as PNAME1_0_, personel1_.PPHONE as PPHONE1_0_ from TBLMANAGER manager0_ left outer join TBLPERSONEL personel1_ on manager0_.ID=personel1_.PERSONEL_ID where manager0_.ID=?
Hibernate: select manager0_.ID as ID0_1_, manager0_.PASSWORD as PASSWORD0_1_, manager0_.PERSONEL_ID as PERSONEL3_0_1_, personel1_.PERSONEL_ID as PERSONEL1_1_0_, personel1_.PADDRESS as PADDRESS1_0_, personel1_.PFAMILY as PFAMILY1_0_, personel1_.PNAME as PNAME1_0_, personel1_.PPHONE as PPHONE1_0_ from TBLMANAGER manager0_ left outer join TBLPERSONEL personel1_ on manager0_.ID=personel1_.PERSONEL_ID where manager0_.ID=?
Hibernate: select manager0_.ID as ID0_1_, manager0_.PASSWORD as PASSWORD0_1_, manager0_.PERSONEL_ID as PERSONEL3_0_1_, personel1_.PERSONEL_ID as PERSONEL1_1_0_, personel1_.PADDRESS as PADDRESS1_0_, personel1_.PFAMILY as PFAMILY1_0_, personel1_.PNAME as PNAME1_0_, personel1_.PPHONE as PPHONE1_0_ from TBLMANAGER manager0_ left outer join TBLPERSONEL personel1_ on manager0_.ID=personel1_.PERSONEL_ID where manager0_.ID=?

2 个答案:

答案 0 :(得分:0)

您在“applicationContext.xml”中设置数据库访问权限的方式是什么?

答案 1 :(得分:0)

防止更新时的会话丢失问题,dao中的更改:

public class PersonelDao implements IPersonelDao {
    ...
    public Personel updatePersonel(Personel personel) {
        final Session session = getSessionFactory().getCurrentSession();
        if(session.contains(personel)){
            session.update(personel);
        } else {
            personel = (Personel) session.merge(personel);
        }
        return personel;
    }
    ...
}

因此,如果实体不在会话中,将被强制将其与合并链接。

您还必须检索合并返回的对象,您可能不得不强制并更改内存中的引用。

此致