gpt4 book ai didi

java - JDBC 与 MySQL - SELECT ... IN

转载 作者:行者123 更新时间:2023-11-29 13:41:48 26 4
gpt4 key购买 nike

使用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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com