gpt4 book ai didi

java - 在下面提到的场景中如何将列表传递给sql查询

转载 作者:行者123 更新时间:2023-12-01 12:42:43 26 4
gpt4 key购买 nike

我必须将列表传递给用户选择的存储过程。该列表我在 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/

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