Обновление для hibernate и spring MVC не работает

#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:

Попробуйте

  1. измените слияние с помощью обновления

    SessionFactory.getCurrentSession().update(пользователь);

  2. Если 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);
    }
}