#java #spring #hibernate #jsp
#java #spring #гибернация #jsp
Вопрос:
Я не могу обновить таблицу после ее редактирования, поскольку она работает нормально, когда я отлаживаю и отображаю все значения в файле DAO, но после реализации dao она не показывает обновленное значение для того же самого в списке пользователей. Настоящим я прилагаю свой код:
Файл JSP:
<form:form id="editForm" modelAttribute="user" action="update">
<div style="width: 400px; padding: 10px; border: 5px solid gray; margin: 0px;">
<table width="400px" height="150px">
<tr><td><font face="Arial">First Name:</font></td>
<td><input name="licenseNumber" value="${model.user.firstName}"></td></tr>
<tr><td><font face="Arial">Last Name:</font></td>
<td><input name="licenseNumber" value="${model.user.lastName}"></td></tr>
<tr><td><font face="Arial">Gender:</font></td>
<td><input name="licenseNumber" value="${model.user.gender}"></td></tr>
<tr><td><font face="Arial">City Name:</font></td>
<td><input name="licenseNumber" value="${model.user.city}"></td></tr>
<tr><td></td><td>
<input type="submit" value="Edit" />
<br>
<a href="userList.html" >Cancel</a>
</td></tr>
</table>
</div>
</form:form>
Метод Dao:
@Override
public void updateUser (User user)
{
/*Transaction tx = session.beginTransaction();*/
sessionfactory.getCurrentSession().merge(user);
}
Класс обслуживания
@Service
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public class UserServiceImpl implements UserService {
@Autowired
UserDao userDao;
@Override
public void addUser(User user)
{
userDao.saveUser(user);
}
@Override
public List<User> getUser()
{
return userDao.getUser();
}
@Override
public User getUser(int id)
{
return userDao.getUser(id);
}
@Override
public void updateUser(User user)
{
userDao.updateUser(user);
}
}
Класс контроллера
@RequestMapping(value = "/edit", method = RequestMethod.GET)
public ModelAndView editUserData(@ModelAttribute("user") User user,
BindingResult result) {
Map<String, Object> model = new HashMap<String, Object>();
model.put("user", userService.getUser(user.getId()));
return new ModelAndView("Edit","model",model);
}
@RequestMapping(value = "/update", method = RequestMethod.POST)
public ModelAndView updateUserData(@ModelAttribute("user") User user,
BindingResult result,SessionStatus status) {
userService.updateUser(user);
status.setComplete();
return new ModelAndView("redirect:/userList.html");
}
Ответ №1:
Попробуйте
-
измените слияние с помощью обновления
SessionFactory.getCurrentSession().update(пользователь);
-
Если 1 не работает, попробуйте с:
sessionfactory.getCurrentSession().merge(пользователь); SessionFactory.getCurrentSession().update (пользователь);
Ответ №2:
Вы устанавливаете все свои методы @Transactional как доступные только для чтения = «true». Вы должны переопределить все методы, которые вносят изменения в базы данных.
@Service
@Transactional(propagation = Propagation.SUPPORTS, readOnly = true)
public class UserServiceImpl implements UserService {
@Autowired
UserDao userDao;
@Override
@Transactional(propagation = Propagation.SUPPORTS, readOnly = false)
public void addUser(User user)
{
userDao.saveUser(user);
}
@Override
public List<User> getUser()
{
return userDao.getUser();
}
@Override
public User getUser(int id)
{
return userDao.getUser(id);
}
@Override
@Transactional(propagation = Propagation.SUPPORTS, readOnly = false)
public void updateUser(User user)
{
userDao.updateUser(user);
}
}