作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用PreparedStatement构建一个如下所示的查询...
SELECT * FROM table1 WHERE column1 IN ('foo', 'bar')
...不知道 IN 语句中的字符串数量
构造一个字符串,例如...
"'foo', 'bar'"
...并用 ps.setString() 传递它会导致:
"\'foo\', \'bar\'"
这可能是一件好事,但它使得这种解决我的问题的方法毫无用处。
关于如何将未知数量的值传递到 JDBCPreparedStatement而不动态创建查询字符串的任何想法(此查询存在于一个文件中以便于重用,我想保留就这样)?
最佳答案
我倾向于使用一种会修改查询的方法来相应地修改查询。这是一个基本示例,为简单起见省略了错误处理:
public String addDynamicParameters(String query, List<Object> parameters) {
StringBuilder queryBuilder = new StringBuilder(query);
queryBuilder.append("?");
for (int i = 1; i < parameters.size(); i++) {
queryBuilder.append(", ?");
}
queryBuilder.append(") ");
return queryBuilder.toString();
}
public void addParameters(PreparedStatement pstmt, List<Object> parameters) {
int i = 1;
for(Object param : parameters) {
pstmt.setObject(i++, param);
}
}
public void testDynamicParameters() {
String query = "SELECT col3 FROM tableX WHERE col1 = ? AND col2 IN (";
List<Object> parametersForIn = ...;
query = addDynamicParameters(query, parametersForIn);
List<Object> parameters = ...;
PreparedStatement pstmt = ...; //using your Connection object...
parameters.addAll(parametersForIn);
addParameters(pstmt, parameters);
//execute prepared statement...
//clean resources...
}
关于java - JDBC 与 MySQL - SELECT ... IN,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17977410/
我是一名优秀的程序员,十分优秀!