Mysql Java Derby Netbeans不允许使用“deleteRow”,因为ResultSet不是可更新的ResultSet
我试图删除一行,但它不允许我,它说“'deleteRow'不允许,因为结果集不是可更新的结果集”。这是我的代码:
public void addUserName() throws SQLException {
rs = st.executeQuery("select NAME, prize from usernames");
try {
while (rs.next()) {
String attribute2 = rs.getString("name");
if (attribute2.equals(getName())){
String toPrint = rs.getString(2);
System.out.println("Welcome back " + getName());
System.out.println("You previously won " + toPrint);
System.out.println("Let's see if you can do any better this time :)");
rs.deleteRow();
}
}
} catch (SQLException ex) {
Logger.getLogger(Millionaire.class.getName()).log(Level.SEVERE, null, ex);
}
}
我做错了什么?如有任何建议,将不胜感激。提前谢谢
这就是我创建表的方式,并添加了给定的建议,但仍然得到相同的错误:
public void createTable(String tableName) {
try {
Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_UPDATABLE);
//String newTable = "millionair";
//statement.executeUpdate("drop table if exists "+newTable);
String sqlCreateTable = "CREATE TABLE " + tableName + " (NAME VARCHAR(50), PRIZE INT)";
stmt.executeUpdate(sqlCreateTable);
} catch (SQLException ex) {
System.err.println("SQLException: " + ex.getMessage());
}
}
# 1 楼答案
来自docs
因此,在创建语句时,必须设置
ResultSet.CONCUR_UPDATABLE
属性