我正在尝试创建一个像这样的通用UPDATE-statement,其中只有表名是固定的。
updateValueQuery = conn.prepareStatement("UPDATE TABLENAME SET (?)=(?)");这将失败,并显示SQLException对语法的抱怨。只要我像这样指定column-name:
updateValueQuery = conn.prepareStatement("UPDATE TABLENAME SET COL_NAME=(?)");SQL愉快地编译。有没有办法让列名也匿名呢?
我使用的是Apache derby。
发布于 2013-07-16 21:59:31
不,PreparedStatement只有值的定位符。我通过以下方式解决了类似的问题:
private final String FIND_STRING = "select * from TABLENANE where {0} = ?";
.
.
.
private final Map<String, PreparedStatement> statements = new HashMap<String, PreparedStatement>();
private PreparedStatement prepareStatement(String field, String toFind) throws SQLException{
PreparedStatement statement = null;
if (statements.contains(field)){
statement = statements.get(field);
}else{
String findInHelpDefinition = MessageFormat.format(FIND_STRING, field));
statement = connection.prepareStatement(findInHelpDefinition);
statemnts.put(field, statement);
}
statement.setString(1, toFind);
return statement;
}https://stackoverflow.com/questions/17678097
复制相似问题