Hibernate4执行save()或update()无效

简介:

        最近在写网上商城项目时,遇到一个问题:hibernate在执行save()或者update()方法后,并没有任何效果,数据库中没有任何改动,而且控制台也没有报任何错,这让我很无语……

        我在网上查了下,有的人说是主键的自增长问题,有的人说是没有开启事务,所以无法写入或更新数据库,我详细看了他们的分析,说的都有道理,但是这些解决方法对我都不管用,因为我的主键是没有问题的,事务是由spring管理的,在其他save操作都可以,都没有问题。

        既然客观上都没有问题,于是我把焦点放在了具体要save或update的对象上了,对POJO做了仔细的分析,首先看一下我要save的对象对应数据库中的表:

[sql]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. /*=============================*/  
  2. /* Table: 商品表结构            */  
  3. /*=============================*/  
  4. create table product  
  5. (  
  6.    /* 商品编号,自动增长 */  
  7.    id                  int primary key not null auto_increment,  
  8.    /* 商品名称 */  
  9.    name                varchar(50),  
  10.    /* 商品价格 */  
  11.    price               decimal(8,2),  
  12.    /* 商品图片 */  
  13.    pic                 varchar(300),  
  14.    /* 商品简单介绍 */  
  15.    remark              longtext,  
  16.    /* 商品详细介绍 */  
  17.    xremark             longtext,  
  18.    /* 商品生产日期 */  
  19.    date                timestamp default CURRENT_TIMESTAMP,  
  20.    /* 是否为推荐商品,推荐商品才有可能显示在商城首页 */  
  21.    commend             bool,  
  22.    /* 是否为有效商品,有效商品才有可能显示在商城首页 */  
  23.    open                bool,  
  24.    /* 商品所在的类别编号*/  
  25.    cid                  int,  
  26.    constraint cid_FK foreign key(cid) references category(id)  
  27. );  
        然后具体的POJO就不贴上来了,就是根据这张表生成的一些字段属性以及set和get方法。我觉得最有可能出问题的字段应该就是这个时间date,于是我看了下POJO里关于date的代码:

[java]  view plain  copy
  在CODE上查看代码片 派生到我的代码片
  1. @Entity  
  2. public class Product implements java.io.Serializable {  
  3.   
  4.     // Fields  
  5.     private Timestamp date;  
  6.   
  7.     //省略其他无关代码……  
  8.   
  9.     @Column(name = "date", nullable = false, length = 19)  
  10.     public Timestamp getDate() {  
  11.         return this.date;  
  12.     }  
  13.   
  14.     public void setDate(Timestamp date) {  
  15.         this.date = date;  
  16.     }  
  17. }  
        于是我再一次上网搜索了这个Timestamp,发现问题就出在这,将Timestamp改成java.util.Date即可。然后传进来一个Date对象,Hibernate会自动转成Timestamp类型。

        这个问题也给我一个启示:无法执行数据库操作也有可能是对象本身的问题,要从表的字段和POJO属性之间来排查。

_____________________________________________________________________________________________________________________________________________________

-----乐于分享,共同进步!

-----更多文章请看:http://blog.csdn.net/eson_15

相关文章
|
Java 数据库连接 数据库
【hibernate 执行方法未插入数据库】hibernate的save方法成功执行,但是未插入到数据库
今天做项目,碰上这个问题: hibernate的save方法成功执行,但是未插入到数据库。 Dao层代码: 1 @Override 2 public void save(T t) { 3 this.
1081 0
|
Java 数据库连接 数据库
Hibernate save, saveOrUpdate, persist, merge, update 区别
Hibernate Save hibernate save()方法能够保存实体到数据库,正如方法名称save这个单词所表明的意思。我们能够在事务之外调用这个方法,这也是我不喜欢使用这个方法保存数据的原因。
1300 0
|
Java 数据库连接 Spring
Exception in thread "main" org.hibernate.HibernateException: save is not valid without active transa
  Exception in thread "main" org.hibernate.HibernateException: save is not valid without active transaction at org.hibernate.context.ThreadLocalSessionContext$TransactionProtectionWrap
1483 0
|
安全 Java 应用服务中间件
Java 近期新闻:Hibernate 6.0、JobRunr 5.0、JHipster 7.8.0、Spring CVEs、JReleaser 1.0-RC2
本期 Java 近期新闻综述内容涉及 JDK 19、Spring Boot、Spring CVEs、Apache Tomcat 点版本、Quarkus Tools for Visual Studio Code、Micronaut 3.4.1、JetBrains 加入 Micronaut 基金会、Open Liberty Paketo Liberty Buildpack、Hibernate 6.0、JobRunr 5.0、WildFly 26.1 Beta S2I 镜像、JReleaser 1.0-RC2、MicroStream 7.0-M2、JHipster 7.8.0、JMH 1.35。
782 0
|
18天前
|
SQL Java 数据库连接
jpa、hibernate、spring-data-jpa、jdbcTemplate
jpa、hibernate、spring-data-jpa、jdbcTemplate
|
4月前
|
存储 Java 数据库连接
Spring Boot 嵌入式服务器、Hibernate 关系和 Spring Data 全解析
Spring Boot 的嵌入式服务器功能是一项方便而强大的功能,它允许你在应用程序中直接运行 Web 服务器,无需将其部署到单独的独立 Web 服务器中。这使得开发、测试和部署 Web 应用程序变得容易,而且它还是轻量级的、易于启动和停止的,易于配置。
67 0
|
4月前
|
XML Java 数据库连接
Hibernate与Spring整合实践实例
Hibernate与Spring整合实践实例
40 0
|
7月前
|
存储 Oracle Java
[亲测可用]hibernate调用Oracle存储过程|Spring Data JPA调用Oracle存储过程方法
[亲测可用]hibernate调用Oracle存储过程|Spring Data JPA调用Oracle存储过程方法
|
9月前
|
Java 数据库连接 数据库
JAVA三大框架Struts、hibernate和spring的各自作用是什么?
JAVA三大框架Struts、hibernate和spring的各自作用是什么?
48 0