我必须将列表传递给用户选择的存储过程。
该列表我在 java 末尾以字符串形式存在。
示例:String list="123,467,980";
现在,如果我按原样将该字符串放入存储过程,那么它将如何工作。
我无法使用它,如下所述:
select * from table_name where code in (list_var)
谁能指导我实现此功能的最佳方法是什么。
最佳答案
在客户端编写 SQL:
String sql = "select * from table_name where code in (" + list_var + ")";
或者,如果您想要调用存储过程,则实际参数应该是 list
字符串中表示的参数:
String [] ids = list.split(",");
String sql = "{call yourProcedure(";
for(int i = 0; i < ids.length; i++)
sql += (i == 0?"":",") + "?";
sql += ")}";
CallableStatement cst = con.prepareCall(sql);
for(int i = 0; i < ids.length; i++)
cst.setInt(i+1, Integer.parseInt(ids[i]));
或者:
String sql = "{call yourProcedure(" + list + ")}";
CallableStatement cst = con.prepareCall(sql);
关于java - 在下面提到的场景中如何将列表传递给sql查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24952475/