0
    package com.jee6.beans;

import com.jee6.entity.Employee;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.annotation.Resource;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.persistence.*;
import javax.transaction.SystemException;

@ManagedBean
@SessionScoped
public class EmployeeBean {
@PersistenceContext(unitName = "ServicePU")
private EntityManager em;
@Resource
private javax.transaction.UserTransaction utx;
private List<Employee> emplist=new ArrayList<Employee>();
//private Query sql="SELECT e FROM Employee e";
private Employee emp= new Employee();


public Employee getEmp() {
    return emp;
}

public void setEmp(Employee emp) {
    this.emp = emp;
}

public List<Employee> getEmplist() {
    return emplist=findAll();
}

public void setEmplist(List<Employee> emplist) {
    this.emplist = emplist;
}

public List<Employee> findAll(){
    emplist=(List<Employee>)em.createQuery("Select e From Employee e").getResultList();
    return emplist;
}
public EmployeeBean() {
}
public String saveEmployee(){
    persist(emp);
    return null;
}
public String deleteEmployee(Employee e){
   try{
       em.remove(e);
       emplist=findAll();
   } 
       catch (Exception ex)
    {
     Logger.getLogger(getClass().getName()).log(Level.SEVERE, "exceptioncaught", ex);
    }
   return null;
 }
 public void persist(Object object) {
    try {
        utx.begin();
        em.persist(object);
        utx.commit();
    } catch (Exception e) {
      Logger.getLogger(getClass().getName()).log(Level.SEVERE, "exception caught", e);
        throw new RuntimeException(e);
    }
}

}

我想从 JSF 中的 DataTable 中删除数据,上面的代码没有输出。我正在尝试修复该代码并且没有输出。在此之前,我在 (em.remove(e);) 的删除方法中遇到了 IllegalException。有没有人可以纠正我并对此表示赞赏。

4

1 回答 1

0

由于您没有使用 EJB,因此您必须手动管理所有数据库事务。每次通过 JPA 对实体执行数据库操作时,您都需要致电begin()commit()自己。你没有在方法中这样做。EntityManagerdeleteEmployee()

更好的做法是将所有 JPA 工作转移到EJB 中,然后像在托管 bean 类@Stateless中一样依次注入它。@EJB这样您就不必再担心交易了。有关启动示例,另请参阅此答案的“更新”部分:JSF managed-bean EJB injection


与具体问题无关,您的吸气剂根本不应该执行数据库操作。每次调用该方法时,您getEmplist()都在调用数据库。这是不必要的昂贵。而是在 bean 的@PostConstruct方法中完成这项工作。另请参阅为什么 JSF 多次调用 getter

于 2012-06-28T16:04:35.383 回答