使用Java的DB2 Sequence值

我需要从DB2序列中获取下一个值.这是我尝试过的一种方法stmt = con.createStatement();rs = stmt.executeQuery(db2 VALUES NEXTVAL FOR sequence_name); rs.close();stmt.close(); 我得到的错误如下:com.ibm....

我需要从DB2序列中获取下一个值.这是我尝试过的一种方法

stmt = con.createStatement();
rs = stmt.executeQuery("db2 VALUES NEXTVAL FOR <sequence_name>"); 

rs.close();
stmt.close(); 

我得到的错误如下:

com.ibm.db2.jcc.c.SqlException: [ibm][db2][jcc][10103][10941] Method executeQuery cannot be used for updates.
           at com.ibm.db2.jcc.c.qh.a(qh.java:2390)
           at com.ibm.db2.jcc.c.qh.a(qh.java:1751)
           at com.ibm.db2.jcc.c.qh.a(qh.java:478)
           at com.ibm.db2.jcc.c.qh.executeQuery(qh.java:462)
           at test.pack.SequenceConn.getNextSequenceValue(SequenceConn.java:59)
           at test.pack.SequenceConn.main(SequenceConn.java:22)

如何从序列中检索下一个值?

解决方法:

管理自己解决这个问题.

stmt = con.createStatement();
rs = stmt.executeQuery("VALUES NEXTVAL FOR <sequence_name>"); 

rs.close();
stmt.close();

基本上,查询字符串中的前面的db2导致了问题.删除它,并能够获得序列值.

本文标题为:使用Java的DB2 Sequence值

基础教程推荐