发布于 2016-07-03 05:31:27 | 297 次阅读 | 评论: 1 | 来源: 网友投递

这里有新鲜出炉的Hibernate教程,程序狗速度看过来!

Hibernate 开源对象关系映射框架 ORM

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。


这篇文章主要为大家详细介绍了解决Hibernate4执行save()或update()无效问题的方法,感兴趣的小伙伴们可以参考一下

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


/*=============================*/ 
/* Table: 商品表结构      */ 
/*=============================*/ 
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属性之间来排查。

原文链接:http://blog.csdn.net/eson_15/article/details/51383298

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



最新网友评论  共有(1)条评论 发布评论 返回顶部
ddihpc 发布于2016-09-17 07:17:57
终于搞明白了.
支持(0)  反对(0)  回复

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务