Hibernate使用DB2 for Z/OS 序列 的一个BUG

Hibernate-3.2.6.ga 使用DB2 for Z/OS(DB8G) 序列 有一个BUG,

Hibernate: values nextval for seq_id
警告:SQL Error:-99999,SQLState:null
...........
org.hibernate.exception.genericJDBCException:Could not get next sequence value


经查看资料values nextval for seq_id  (seq_id是序列名)是不正确的,可能是DB8G之前版本使用的语句,在使用pcome登录主机db28G数据库后,执行插入语句,使用序列时要使用next value for seq_id

我修改了hibernate的org.hibernate.dialect.DB2Dialect里面的

getSequenceNextValString(String sequenceName)方法

原方法如下:

 

public String getSequenceNextValString(String sequenceName) {
        return "values nextval for " + sequenceName;
    }

把返回值改为:"next value for"+sequenceName

然后重新编译DB2Dialect.java,生成的class文件,替换hibernate3.jar中的class

错误依旧:Could not get next sequence value

后来又查看了那些类调用了getSequenceNextValString方法,结果发现在org.hibernate.id.equenceGenerator.java里调用了该方法:

首先

构造函数调用getSequenceNextValString给成员变量sql赋值

sql = dialect.getSequenceNextValString(sequenceName);

最后在AccessCallback buildCallback(final SessionImplementor session)方法里调用了

PreparedStatement st = session.getBatcher().prepareSelectStatement(sql);
   try {
    ResultSet rs = st.executeQuery();
    try {
     rs.next();
     Serializable result = IdentifierGeneratorFactory.get(
       rs, identifierType
      );
     if ( log.isDebugEnabled() ) {
      log.debug("Sequence identifier generated: " + result);
     }
     return result;
    }
    finally {
     rs.close();
    }
   }

.....

就是这里来,hibernate在这里获得序列的下一个值,

而不是在sql语句(如insert into)中使用next value for seq_id

next value for不是合法的sql语句,所以不会获得序列值

在db8G for zos中是使用sql语句:SELECT NEXT VALUE FOR seq_name FROM SYSIBM.SYSDUMMY1 来获得下一个序列值得

所以要是用hibernate使用序列,就要把DB2Dialect返回值改成这样:

public String getSequenceNextValString(String sequenceName) {
        return "SELECT NEXT VALUE FOR " + sequenceName +" FROM SYSIBM.SYSDUMMY1";
    }

 

修改完毕,重新编译改java文件,生成的class文件,替换hibernate3.jar中的class,

就可以使用hibernate使用db2 for zos的序列了

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/15082138/viewspace-582454/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/15082138/viewspace-582454/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值