gpt4 book ai didi

java - Hibernate UPDATE 查询将其他值设置为 NULL

转载 作者:行者123 更新时间:2023-11-29 22:00:39 25 4
gpt4 key购买 nike

我有下表用于在 MySQL 中存储我的博客文章:

+-----------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-----------+--------------+------+-----+---------+----------------+
| PostID | int(11) | NO | PRI | NULL | auto_increment |
| PostTitle | varchar(250) | YES | | NULL | |
| PostDate | datetime | YES | | NULL | |
| OwnerID | int(11) | YES | MUL | NULL | |
| PostVote | int(11) | YES | | NULL | |
+-----------+--------------+------+-----+---------+----------------+

我想使用 hibernate UPDATE 查询仅更新 PostVote

这是我的 JAVA 方法:

@PUT
@Consumes({ MediaType.APPLICATION_JSON })
public void updateVotes (Posts p) {
Session ses = HibernateUtil.currentSession();
Transaction tx = null;
try{
tx =ses.beginTransaction();
ses.createQuery("UPDATE Posts SET PostVote="+p.getPostVote() +" WHERE PostID="+p.getPostID()+" AND OwnerID="+p.getOwnerID());
ses.update(p);
tx.commit();
}catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
}finally {
HibernateUtil.closeSession();
}
}

我在 Posts P (Post ID,PostVote,OwnerID) 中仅使用 3 个参数调用此方法,因为这些是我的查询所需的唯一参数。但是,一旦执行查询,除了这 3 个值之外,所有其他值都将设置为 NULL。这是 hibernate 查询输出:

Hibernate: update posts set PostTitle=?, PostDate=?, OwnerID=?, PostVote=? where PostID=?

这显然看起来不太好,因为它似乎更新了不需要的元素。有什么建议我的实际查询中可能有什么问题吗?

最佳答案

使用dynamic-update=true

查看此链接,它可能对您有帮助

http://www.mkyong.com/hibernate/hibernate-dynamic-update-attribute-example/

关于java - Hibernate UPDATE 查询将其他值设置为 NULL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32693205/

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