员工实体
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)
答案 0 :(得分:0)
嗯,你确实明确说过:@ManyToOne(optional=false)
意思是它不能为。