2

primfaces データテーブルの行を編集したいです。私はjsf hibernate spring primefacesの統合を使用しています。しかし、私は次のエラーがあります。

javax.el.ELException: /personel.xhtml @60,83 listener="#{personelMB.updatePersonel(personel.personel_id)}": org.springframework.orm.hibernate4.HibernateOptimisticLockingFailureException: Batch update returned unexpected row count from update [0]; actual row count: 0; expected: 1; nested exception is org.hibernate.StaleStateException: Batch update returned unexpected row count from update [0]; actual row count: 0; expected: 1

個人管理Bean:

@ManagedBean(name="personelMB")
@ViewScoped
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 updatePersonel(int personel_id){
        Personel personel=(Personel)personelservice.getPersonelId(personel_id);
        getPersonelservice().updatePersonel(personel);
    }

}

personel.xhtml:

<h:form  prependId="false">  

    <p:dataTable id="pdataTable" var="personel" value="#{personelMB.personelList}" rowKey="#{personelMB.personel_id}" editable="true"
    >  
  <p:ajax event="rowEdit" update="@this" listener="#{personelMB.updatePersonel(personel.personel_id)}"/>
        <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:cellEditor>
        <f:facet name="output">  
            <h:outputText value="#{personel.pname}" />
            </f:facet>
            <f:facet name="input">
              <h:inputText value="#{personel.pname}" />
              </f:facet>
            </p:cellEditor> 
        </p:column>  

        <p:column headerText="نام خانوادگی"> 
         <p:cellEditor> 
         <f:facet name="output">
            <h:outputText value="#{personel.pfamily}" /> 
            </f:facet>
            <f:facet name="input">
            <h:inputText value="#{personel.pfamily}" />
            </f:facet> 
            </p:cellEditor>  
        </p:column>  

        <p:column headerText="آدرس"> 
         <p:cellEditor> 
         <f:facet name="output">
            <h:outputText value="#{personel.paddress}" />  
            </f:facet>
            <f:facet name="input">
            <h:inputText value="#{personel.paddress}" />
            </f:facet>
            </p:cellEditor> 
        </p:column>  
   <p:column headerText="تلفن"> 
   <p:cellEditor> 
   <f:facet name="output">
            <h:outputText value="#{personel.pphone}" />
            </f:facet> 
            <f:facet name="input">
            <h:inputText value="#{personel.pphone}" /> 
            </f:facet>
            </p:cellEditor>
        </p:column>

   <p:column headerText="ويرايش">

         <p:rowEditor /> 



   </p:column>
        <f:facet name="footer">  
            تعداد رکورد#{fn:length(personelMB.getPersonelList())} میباشد.  
        </f:facet>  

    </p:dataTable>  

</h:form> 

パーソナルサービス:

@Transactional(readOnly=true)
public class PersonelService implements IPersonelService{
    IPersonelDao personeldao;
//getter and setter
@Transactional(readOnly=false)
    @Override
    public void updatePersonel(Personel personel) {
        getPersoneldao().updatePersonel(personel);

    }

個人名:

public class PersonelDao implements IPersonelDao {
private SessionFactory sessionFactory;
//getter and setter
@Override
public void updatePersonel(Personel personel) {
    getSessionFactory().getCurrentSession().update(personel);

}

データ テーブルを編集してデータベースに保存する方法を教えてください。

4

1 に答える 1

0

これは、あるトランザクションでHibernateエンティティをフェッチし、別のHibernateセッションで別のトランザクションでそれを更新しようとする問題です。

これを適切に行うPersonelには、同じトランザクションでオブジェクトをフェッチしてから更新する必要があります。@Transactionalつまり、ManagedBeanから呼び出す1つのビジネスロジックメソッドで両方を実行する必要があります。

IPersonelService実装クラスの場合:

@Transactional
public void updatePersonel(int personel_id, String pname, String pfamily ...){
    Personel personel = personelDao.getPersonel(personel_id);
    personel.setPName(pname);
    ....
    getSessionFactory().getCurrentSession().saveOrUpdate(personel); 
} 

これにより、ビジネスロジックがプレゼンテーションロジックから分離され、すべてのデータベース呼び出しが単一のトランザクションの背後で行われます。

于 2012-08-07T11:13:31.853 に答える