Hibernate Mapping - 外键列不能为null - Spring JSP

时间:2017-09-27 19:46:19

标签: java spring hibernate null hibernate-mapping

员工实体

import java.util.List;

@Entity
@Table(name = "EMPLOYEE")
public class Employee {
    @Id
    @Column(name = "wid")
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Integer wid;

    @ManyToOne(optional = false)
    @JoinColumn(name = "bid")
    private BloodGroup bloodgroup;

    public Employee() {
    }

    public Integer getWid() {
        return this.wid;
    }

    public void setWid(Integer wid) {
        this.wid = wid;
    }

    public BloodGroup getBloodgroup() {
        return bloodgroup;
    }

    public void setBloodgroup(BloodGroup bloodgroup) {
        this.bloodgroup = bloodgroup;
    }
}

血型实体

@Entity
@Table(name="BLOODGROUP")
public class BloodGroup {
    @Id
    @Column(name = "bid")
    @GeneratedValue (strategy= GenerationType.AUTO)
    private Integer bid;

    @Size(min=1,max = 30)
    @Column(name = "blood_name")
    private String blood_name;

    @OneToMany(mappedBy = "bloodgroup",fetch=FetchType.LAZY,
            targetEntity=Employee.class, cascade=CascadeType.PERSIST)
    private List<Employee> emp;
    public BloodGroup() {

    }
    public Integer getBid() {
        return bid;
    }
    public void setBid(Integer bid) {
        this.bid = bid;
    }
    public String getBlood_name() {
        return blood_name;
    }
    public void setBlood_name(String blood_name) {
        this.blood_name = blood_name;
    }
    public List<Employee> getEmp() {
        return emp;
    }
    public void setEmp(List<Employee> emp) {
        this.emp = emp;
    }
}

EmployeeDaoImpl

import com.springmvc.model.BloodGroup;
import com.springmvc.model.Employee;

@Repository("employeeDao")
public class EmployeeDaoImpl extends AbstractDao<Integer, Employee>
        implements EmployeeDao {
    @Override
    public void save(Employee employee) {
        persist(employee);
    }

    @Override
    public List<Employee> allEmployee() {
        Criteria criteria = createEntityCriteria();
        return (List<Employee>) criteria.list();
    }
}

EmployeeServiceImpl

import com.springmvc.service.employeeService;

@Service("EmployeeService")
@Transactional
public class employeeServiceImpl implements employeeService {
    @Autowired
    private EmployeeDao dao;

    @Override

    public void save(Employee employee) {
        dao.save(employee);
    }

    @Override
    public List<Employee> allEmployee() {

        return dao.allEmployee();
    }
}

App Controller

@RequestMapping(value = {"/new-emp"}, method = RequestMethod.GET)
public String newEmp(ModelMap model) {
    Employee employee = new Employee();
    model.addAttribute("employee", employee);

    ///////// Blood Group List
    List<BloodGroup> bloodgroup = bloodService.allBloodGroup();
    model.addAttribute("bloodgroupList", bloodgroup);
    return "addEmp";
}

// Call on Submission of 'Save or Update' Button Add Employee
@RequestMapping(value = {"/new-emp"}, method = RequestMethod.POST)
public String addEmp(@Valid Employee employee, BindingResult result,
                     ModelMap model,
                     final RedirectAttributes redirectAttributes, HttpServletRequest
                             request, HttpServletResponse response) {
    wService.save(employee);

    return "addEmp";
}

JSP页面

<form:form method="POST" modelAttribute="employee">
    <form:input type="hidden" path="wid" id="wid"/>

    <label for="bloodgroup">Blood Group:</label>
    <form:select path="bloodgroup" items="${blood}"
                 itemValue="bid" itemLabel="blood_name" name="blood1"/>

    <c:choose>
        <c:when test="${edit}">
            <input type="submit" value="Update"/>
        </c:when>

        <c:otherwise>
            <input type="submit" value="Save"/>
        </c:otherwise>
    </c:choose>

</form:form>
  

HTTP状态500 - 请求处理失败;嵌套异常是      org.hibernate.exception.ConstraintViolationException:无法执行       声明       com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException:       专栏&#39; bid&#39;不能为空       sun.reflect.NativeConstructorAccessorImpl.newInstance0(本机方法)       sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)       sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)       java.lang.reflect.Constructor.newInstance(Unknown Source)       com.mysql.jdbc.Util.handleNewInstance(Util.java:408)

1 个答案:

答案 0 :(得分:0)

嗯,你确实明确说过:@ManyToOne(optional=false)意思是它不能为