- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
好的,我错过了什么?
我有这样一张表:
CREATE TABLE PUBLIC.RESULTS
(RESULTID IDENTITY NOT NULL,
SOURCEID INTEGER NOT NULL,
PARENTID INTEGER,
NAME VARCHAR(25) NOT NULL,
VALUE CLOB NOT NULL,
PRIMARY KEY (RESULTID))
我试过让 RESULTID 既是具有 AUTO_INCREMENT 的 INTEGER 又是 IDENTITY 类型。
我正在使用准备好的语句,无论我做什么,在尝试设置 a 的值时我都会抛出“无数据”异常:
String sql = "INSERT INTO RESULTS (SOURCEID, PARENTID, NAME, VALUE) VALUES (?, ?, ?, ?)";
PreparedStatement stmt = null;
stmt = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
... {Truncated setting of values} ...
stmt.executeUpdate();
conn.commit();
ResultSet rs2 = stmt.getGeneratedKeys();
rs2.next();
Integer a = rs2.getInt(1);
当我实际查看数据库时,数据已正确插入,为 RESULTID 字段设置的下一个值也很好,我似乎无法返回该值。
我必须做一些愚蠢的事情,因为这应该有效。有什么想法吗?
因为有人问完整的堆栈跟踪如下:
org.h2.jdbc.JdbcSQLException: No data is available [2000-170]
at org.h2.message.DbException.getJdbcSQLException(DbException.java:329)
at org.h2.message.DbException.get(DbException.java:169)
at org.h2.message.DbException.get(DbException.java:146)
at org.h2.message.DbException.get(DbException.java:135)
at org.h2.jdbc.JdbcResultSet.checkOnValidRow(JdbcResultSet.java:2957)
at org.h2.jdbc.JdbcResultSet.get(JdbcResultSet.java:2963)
at org.h2.jdbc.JdbcResultSet.getInt(JdbcResultSet.java:307)
at com.cigital.db.DefaultDb.storeValue(DefaultDb.java:147)
at com.cigital.db.DefaultDb.processResult(DefaultDb.java:115)
at com.cigital.db.DefaultDb.importScan(DefaultDb.java:84)
at com.cigital.gui.Default.jButImportActionPerformed(Default.java:373)
at com.cigital.gui.Default.access$400(Default.java:26)
at com.cigital.gui.Default$6.actionPerformed(Default.java:131)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1995)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2318)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:387)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:236)
at java.awt.AWTEventMulticaster.mouseReleased(AWTEventMulticaster.java:272)
at java.awt.Component.processMouseEvent(Component.java:6289)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3267)
at java.awt.Component.processEvent(Component.java:6054)
at java.awt.Container.processEvent(Container.java:2041)
at java.awt.Component.dispatchEventImpl(Component.java:4652)
at java.awt.Container.dispatchEventImpl(Container.java:2099)
at java.awt.Component.dispatchEvent(Component.java:4482)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4577)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4238)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4168)
at java.awt.Container.dispatchEventImpl(Container.java:2085)
at java.awt.Window.dispatchEventImpl(Window.java:2478)
at java.awt.Component.dispatchEvent(Component.java:4482)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:644)
at java.awt.EventQueue.access$000(EventQueue.java:85)
at java.awt.EventQueue$1.run(EventQueue.java:603)
at java.awt.EventQueue$1.run(EventQueue.java:601)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87)
at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:98)
at java.awt.EventQueue$2.run(EventQueue.java:617)
at java.awt.EventQueue$2.run(EventQueue.java:615)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:614)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:269)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:184)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:174)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:169)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:161)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:122)
最佳答案
您需要在提交连接之前获取生成的 key ,而不是之后。
关于Java - H2 数据库 - getGeneratedKeys() 不返回任何结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14664888/
我想获取持久对象的 ID。我正在使用 EJB 3.1。 我使用准备好的语句来执行此操作并且效果很好。 ResultSet generatedKeys = statement.getGeneratedK
我将 executeBatch() 与 JDBC 一起使用来插入多行,我想获取插入行的 ID 以进行另一次插入 我为此目的使用此代码: insertInternalStatement = dbConn
我在 try-with-resources 语句中使用了 java 准备语句来访问表 在带有 NetBeans 8.0 IDE 的 Java DB 数据库中。运行 executeUpdate 方法后,
我正在升级到 Grails 2.3.9 的 Hibernate4:4.3.5.3 插件。但是,我收到一个错误: getGeneratedKeys() support is not enabled 我无
我正在尝试做一些在我使用过的每个数据库中都有效的事情。我想从插入中获取生成的 key 。我有 oracle 12c 设置并有下表: CREATE TABLE countyUsers (id integ
这段代码片段 PreparedStatement statement = connect.prepareStatement( query, Statement.RETURN_GEN
我已经了解到 mysql 中的 last_insert_id 不是池安全的。也就是说,如果你正在合并连接,你会弄乱 insert_ids。java 的 statement.getGeneratedKe
我最近从 MySQL 切换到 PostgreSQL 用于项目的后端,并发现我的一些数据库代理方法需要审查。为了插入链接对象,我使用事务来确保所有内容都已存储。我使用诸如 setAutoCommit(f
好的,我错过了什么? 我有这样一张表: CREATE TABLE PUBLIC.RESULTS (RESULTID IDENTITY NOT NULL, SOURCEID INTEGER NOT NU
我想使用 PreparedStatement INSERT 几行: ps = con.prepareStatement(query,PreparedStatement.RETURN_GENERATED
我有一个表,其中有一列定义为自动生成键。执行以下代码时,我希望生成一个新 key ,但事实并非如此。插入一行,但 ps.getGeneratedKeys() 的结果集为空。 我正在使用 DB2:SQL
我希望 JDBI 将自动生成的主键(Long 值)转换为另一个类。 我的 DAO: @RegisterMapper(SystemIdMapper.class) public interface Sys
preparedStatement.getGeneratedKeys() 在查询只有一个 INSERT MySQL 语句时工作正常,但如果查询中有多个语句,它不会返回生成的 ID,即: test 有
我创建的表是这样的: public final String CREATE_QUESTIONS_TABLE = "CREATE TABLE Questions(QuestionID INTEGER P
我正在玩 JDBC/MySQL 5.1。我创建了一个 insert 查询来将一些数据插入到表中,并希望从新创建的行中返回生成的键。但是,当我通过“id”引用列时,这是我的 PK 和自动递增列。 Pre
Python的sqlite3模块中有没有类似于Java的statement.getGeneratedKeys()的API?如果没有,使用 sqlite3 在 Python 中获取最近自动生成的 key
我想使用插入查询检索表中最近更新的值。 这些是我的 sql 表中的数据类型。 数据类型: int(11) // primary key auto increment, not being a
我在 table 上做了一个“简单的”,它给出了这个错误。搜索网络没有帮助。 我认为使用序列作为我的主键源与我有关。 你能帮忙吗?谢谢 我正在尝试运行的代码(我已经突出显示了引发错误的部分)
我正在使用 JDBC 向 MYSQL 数据库中插入一行。我构建了一个参数化命令,执行它并尝试检索自动生成的 key ,如下所示: String sql = "INSERT IGNORE INTO `u
我有一个查询如下: String SQL = "insert into table (id, name) values (sequence.nextval, ?)"; 然后我像这样制作一个 Prepa
我是一名优秀的程序员,十分优秀!