Hibernate4执行save()或update()无效
来源:互联网 发布:沙丁鱼挂机赚钱软件 编辑:程序博客网 时间:2024/05/22 12:55
最近在写网上商城项目时,遇到一个问题: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的代码:
@Entitypublic 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属性之间来排查。
_____________________________________________________________________________________________________________________________________________________
-----乐于分享,共同进步!
5 0
- Hibernate4执行save()或update()无效
- SSH之Hibernate save或update方法已经执行,但是数据库没保存数据
- android lsitview setOnItemLongClickListener 无效或不执行
- android lsitview setOnItemLongClickListener 无效或不执行
- 解决Hibernate的session.save/update/delete操作无效问题(事务管理)
- Hibernate save update merge
- mysql save Or update
- MongoDB save or update
- @DynamicInsert/@DynamicUpdate——Hibernate中只save或update非空字段
- 【PHP】【Mysql】【thinkphp】,Thinkphp save()方法执行update操作的返回值问题
- 判断adodb php执行insert或update是否成功
- Hibernate4 save方法无法保存数据
- Server 2008 下AjaxPro 不执行或无效
- 【error】hibernate4删除、更新无效
- MongoDB小结11 - update【save】
- save(),update(),saveOrUpdate()和merge()
- Hibernatemplete发现save(),delete()无效
- Hibernate4 执行SQL语句
- 掌中行_网站初级搭建
- 基于jQuery的一个简单的图片查看器实现
- Gym 100962F Frank Sinatra
- 动态规划
- LeetCode 029 Divide Two Integers
- Hibernate4执行save()或update()无效
- Load Native-Hadoop Library For Mac
- Word 文档 自定义页眉页脚
- nyoj420 P次方求和(快速幂)
- div table td布局相关属性设置说明
- 聊聊jQuery的反模式
- 用户“Michael-PC\Michael”不具有所需的权限。请验证授予了足够的权限并且解决了 Windows 用户帐户控制(UAC)限制问题。
- libiconv VS2013 x64静态库编译
- codeforces 672C. Recycling Bottles