Chinaunix首页 | 论坛 | 博客
  • 博客访问: 307901
  • 博文数量: 46
  • 博客积分: 1517
  • 博客等级: 上尉
  • 技术积分: 530
  • 用 户 组: 普通用户
  • 注册时间: 2006-12-31 18:21
文章分类

全部博文(46)

文章存档

2012年(1)

2011年(1)

2010年(3)

2009年(2)

2008年(25)

2007年(13)

2006年(1)

我的朋友

分类: Java

2008-08-27 17:14:07

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的序列了

阅读(1676) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

chinaunix网友2008-09-01 00:32:49

朋友你好 我电脑也是vostro1000的 我正准备在本本上装个Ubuntu,朋友你有qq么? 可以加我么 我qq747936847 我建立的Ubuntu群67506582。到时候不懂的还请朋友你多多指教啊