郁闷了,非常简单的hibernate执行hql语句更新操作为什么就不执行

Hibernate的相关问题
1. Hibernate数据库中明明有,但是Get总返回null Oracle的CHAR(15)类型,如果字符串ID不足15个字符,则会自动用空格补齐。 虽然在Sql Plus工具查询的时候,不需要补齐空格。 但是在Hibernate查询的时候需要补齐的。 这也是为何Hibernate get查询的时候,数据
1. Hibernate数据库中明明有,但是Get总返回null
Oracle的CHAR(15)类型,如果字符串ID不足15个字符,则会自动用空格补齐。
虽然在Sql Plus工具查询的时候,不需要补齐空格。
但是在Hibernate查询的时候需要补齐的。
这也是为何Hibernate get查询的时候,数据库中明明有,却返回null的原因之一
2.Hibernate在插入记录的时候,commit等待、假死、不执行下一步的根本原因
Hibernate在插入记录的时候,如果ID(主键值)重叠,则会等待,奇怪。根本原因在于
SQLPlus或者Hibernate操作该数据表没有提交导致。当然如果已经提交了,ORACLE不要求
Hibernate等待的时候,Hibernate本身会抛出异常。
比如SQL PLUS 用delete from school where id=1;但执行完后没有commit
然后Hibernate 要插入id=1的记录,那么ORACLE将让Hibernate等待,一面出现了错误的逻辑。
(感觉ORACLE或者Hibernate也没有设计得多好,因为在Hibernate因为SQL PLUS没有提交时而
等待,但是SQL PLUS 提交(commit)后还是等待,没有事件通知功能)
你最喜欢的hibernate执行更新操作的时候,没有主键会报错
我之前测试过sql语句执行更新操作,与是否有主键,和主键是否为空没有关系。但是hibernate执行更新的时候没有主键就报错。
保存的方法如下:
public void update(T entity) {
this.getHibernateTemplate().merge(entity);
报错如下:
org.hibernate.exception.ConstraintViolationException: could not inser
com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Column 'userid' cannot be null
所以我猜测hibernate内部实现更新的语句应该为:update tableName set culumns... where id = ?
我的解决办法是自己写sql语句解决。
顶一下(0) 踩一下(0)
热门标签:hibernate update语句不执行, hibernate update语句不执行 Ov
hibernate update语句不执行 Override public User select(Integer id) {
session = HibernateUtil.currentSession();
User user = (User)session.load(User.class, id); } Override public int update(User user)订尝斥妒俪德筹泉船沪 {
session = HibernateUtil.currentSession();
session.beginTransaction();
session.update(user);
session.getTransaction().commit();
HibernateUtil.closeSession(session);
return 0; }先select再改变user再update然后没有update语句 心似苍穹气如虹 hibernate update语句不执行
User user = (User)session.load(User.class, id);//改成session.get(User订尝斥妒俪德筹泉船沪.class,id)试试
把hql语句贴出来,可能修改时hql语句写错了吧。
你用merge试试,别用update
热心网友}

我要回帖

更多关于 hibernate直接执行sql 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信