gpt4 book ai didi

java - 相同的值多次添加到数据库中

转载 作者:行者123 更新时间:2023-11-29 07:11:57 26 4
gpt4 key购买 nike

//LoginDAO,将 UI 值保存到数据库中的逻辑...添加新值并替换旧值

System.out.println("In Vendor registration i.e LoginDAO class::::::::::"+vendorRegistration.getVid()+""+""+vendorRegistration.getFirstName());
Session session = getSession();
session.beginTransaction(); //begin transaction for the session.
Query query = session.createQuery("UPDATE VendorRegistration set firstName =:firstname,lastName =:lastname,Email =:email,password =:password,Vid =:vid ");

query.setParameter("firstname",vendorRegistration.getFirstName());
query.setParameter("lastname",vendorRegistration.getLastName());
query.setParameter("email",vendorRegistration.getEmail());
query.setParameter("password",vendorRegistration.getPassword());
query.setParameter("vid",vendorRegistration.getVid());

int user = query.executeUpdate();

session.save(vendorRegistration);
System.out.println("user values are ::::::::::::::::::"+user);
session.getTransaction().commit(); //here transaction complete with commit the data in db.
session.close();



// Controller class

@RequestMapping(value = {"/signup"}, method = RequestMethod.POST)
public String saveRegAction(@ModelAttribute("signup") @Validated VendorRegistration vendorRegistration, Model model,HttpSession session,BindingResult bindingResult) throws IOException
{
System.out.println("the object is:" + model);
if(bindingResult.hasErrors())
{
logger.info("user details===========" +vendorRegistration.getFirstName()+""+vendorRegistration.getLastName()+""+vendorRegistration.getVid()+""+vendorRegistration.getEmail()+""+vendorRegistration.getPassword());
logger.info("Returning home.jsp page");

model.addAttribute("vendor", new VendorRegistration());
return "signup";
}
loginService.saveNewUser(vendorRegistration);
session.setAttribute("vendorRegistration", vendorRegistration);

logger.info("in registration page........... save register action");
return "vendorLogin";

//值多次保存保留旧值并将新值保存到数据库中

![这是数据库的问题][1]][1]

//pojo类

@Entity
@Table(name = "VendorRegistration")
public class VendorRegistration {


@Id
@Column(name = "ID")
@GeneratedValue(strategy = GenerationType.IDENTITY)
private long id;


@Column(name = "VID")
private String vid;

@NotBlank
@Column(name = "FIRSTNAME")
private String firstName;

@Column(name = "LASTNAME")
private String lastName;

@Column(name = "EMAIL")
@Email(message="Please Enter Valid Email ID")
private String email;

@Column(name ="PASSWORD")
private String password;
//getters and setters

最佳答案

您的代码中有一些错误/缺陷。首先是你的 Controller ,它有一个错误的方法签名。

首先修复方法签名,BindingResult 必须直接跟随它所应用的方法参数,在您的情况下为 @ModelAttribute 带注释的元素。

@RequestMapping(value = {"/signup"}, method = RequestMethod.POST)
public String saveRegAction(@ModelAttribute("signup") @Validated VendorRegistration vendorRegistration, BindingResult bindingResult, Model model,HttpSession session,) throws IOException { ... }

您的数据库出现的问题是由于您的 service/dao 方法的实现造成的。您首先执行更新查询,最后插入它。因此,首先会更新所有内容,然后插入新记录。您的方法中应该只有 session.save ,不多不少。

Session session = getSession();                               
session.beginTransaction();

session.save(vendorRegistration);
session.getTransaction().commit();
session.close();

但是,代码的其余部分仍然存在缺陷,因为在出​​现错误/异常的情况下可能会导致连接池匮乏。您应该在代码中使用try/catch/finally。 (或者更好的是让 Spring 通过使用 Spring 管理的事务来为您做到这一点)。

final Session session = getSession();
try {
session.beginTransaction();
session.save(vendorRegistration);
session.getTransaction().commit();
} catch (Exception e) {
session.getTransaction().rollback();
} finally {
session.close();
}

对于与 session 一起使用的每个方法,您基本上都需要类似的东西。如果不这样做,您的 Session 可能会挂起并使用连接池中的连接。如果发生这种情况,您的应用程序将会终止或开始爬行。

更好的是使用 Spring 管理的事务。

@Transactional
public saveNewUser(VendorRegistration vendorRegistration) {
sessionFactory.getCurrentSession().save(vendorRegistration);
}

Spring 现在为您管理 session 和事务。

专业提示:不要使用普通的 hibernate,而是使用 JPA 并使用 Spring Data JPA。那么你只需要这个。

interface VendorRegistrationRepository extends JpaRepository<Long, VendorRegistration> {}

没有实现,只有一个接口(interface),一切都为您管理。

关于java - 相同的值多次添加到数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39369431/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com