- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我创建的表是这样的:
public final String CREATE_QUESTIONS_TABLE = "CREATE TABLE Questions(QuestionID INTEGER PRIMARY KEY GENERATED ALWAYS AS IDENTITY,"
+ "SubmittedTime TIMESTAMP NOT NULL,"
+ "Title VARCHAR(50) NOT NULL,"
+ "Text VARCHAR(300) NOT NULL,"
+ "Username VARCHAR(10) NOT NULL,"
+ "Rating INTEGER DEFAULT 0 NOT NULL)";
我的 INSERT 查询如下所示:
public final String INSERT_QUESTION_STMT = "INSERT INTO Questions(SubmittedTime, Title, Text, Username) VALUES(?,?,?,?)";
我插入的部分 servlet 代码如下所示:
// insert question into database
PreparedStatement pstmt = conn.prepareStatement(AppConstants.INSERT_QUESTION_STMT);
pstmt.setTimestamp(1, new Timestamp(System.currentTimeMillis()));
pstmt.setString(2, newQuestion.getTitle());
pstmt.setString(3, newQuestion.getText());
pstmt.setString(4, (String)session.getAttribute("username"));
pstmt.executeUpdate();
到目前为止,一切正常,并将问题插入数据库。
我想获取问题的自动生成 ID,所以我尝试使用:
ResultSet rs = pstmt.getGeneratedKeys();
int id = -1;
if(rs.next())
id = rs.getInt(1);
我在 rs.next()
SEVERE: Servlet.service() for servlet [AskQuestion] in context with path [/QnA] threw exception
java.lang.NullPointerException
at QnA.servlets.AskQuestion.doPost(AskQuestion.java:78)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:731)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:505)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:169)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:956)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:436)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1078)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:625)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:318)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Unknown Source)
知道为什么它不起作用吗?
最佳答案
我找到了答案,我必须告诉语句返回生成的 key 。
PreparedStatement pstmt = conn.prepareStatement(AppConstants.INSERT_QUESTION_STMT,
Statement.RETURN_GENERATED_KEYS);
请注意 Statement.RETURN_GENERATED_KEYS
作为函数的第二个参数。
关于java - rs.getGeneratedKeys() 在 Derby 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35670858/
我想获取持久对象的 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
我是一名优秀的程序员,十分优秀!