栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

解决Hibernate4执行save()或update()无效问题的方法

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

解决Hibernate4执行save()或update()无效问题的方法

最近在写网上商城项目时,遇到一个问题:Hibernate在执行save()或者update()方法后,并没有任何效果,数据库中没有任何改动,而且控制台也没有报任何错,这让我很无语……
我在网上查了下,有的人说是主键的自增长问题,有的人说是没有开启事务,所以无法写入或更新数据库,我详细看了他们的分析,说的都有道理,但是这些解决方法对我都不管用,因为我的主键是没有问题的,事务是由Spring管理的,在其他save操作都可以,都没有问题。
既然客观上都没有问题,于是我把焦点放在了具体要save或update的对象上了,对POJO做了仔细的分析,首先看一下我要save的对象对应数据库中的表:

 
 
 
create table product 
( 
  
 id     int primary key not null auto_increment, 
  
 name    varchar(50), 
  
 price    decimal(8,2), 
  
 pic     varchar(300), 
  
 remark    longtext, 
  
 xremark    longtext, 
  
 date    timestamp default CURRENT_TIMESTAMP, 
  
 commend    bool, 
  
 open    bool, 
  
 cid     int, 
 constraint cid_FK foreign key(cid) references category(id) 
); 

 然后具体的POJO就不贴上来了,就是根据这张表生成的一些字段属性以及set和get方法。我觉得最有可能出问题的字段应该就是这个时间date,于是我看了下POJO里关于date的代码:

@Entity 
public class Product implements java.io.Serializable { 
 
 // Fields 
 private Timestamp date; 
 
 //省略其他无关代码…… 
 
 @Column(name = "date", nullable = false, length = 19) 
 public Timestamp getDate() { 
  return this.date; 
 } 
 
 public void setDate(Timestamp date) { 
  this.date = date; 
 } 
} 

        于是我再一次上网搜索了这个Timestamp,发现问题就出在这,将Timestamp改成java.util.Date即可。然后传进来一个Date对象,Hibernate会自动转成Timestamp类型。
        这个问题也给我一个启示:无法执行数据库操作也有可能是对象本身的问题,要从表的字段和POJO属性之间来排查。

以上就是本文的全部内容,希望对大家的学习有所帮助。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/149892.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号