请问哪位大虾用过PreparedStatement,SQL语句里包含in(?) 这个里面我要放多个数据,比如: in('first','second','third'),要怎么为参数设置值啊?
2条回答 默认 最新
- hunterli0408 2008-10-15 09:53关注
Connection con = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try {
Class.forName("com.mysql.jdbc.Driver");
con = DriverManager.getConnection(
"jdbc:mysql://127.0.0.1:3306/firefly", "root", "200493128");//创建参数列表 List<String> list = new ArrayList<String>(); list.add("U1"); list.add("U2"); list.add("U3"); //根据参数列表的大小生成in串 StringBuffer buffer = new StringBuffer(); for (int i = 0; i < list.size(); i++) { buffer.append("?, "); } buffer.deleteCharAt(buffer.length() - 1); buffer.deleteCharAt(buffer.length() - 1); pstmt = con.prepareStatement("select * from logon where id in (" + buffer.toString() + ")"); //根据参数列表设置sql参数 for (int i = 0; i < list.size(); i++) { pstmt.setString(i + 1, list.get(i)); } //运行 rs = pstmt.executeQuery(); while (rs.next()) { System.out.println(" id : " + rs.getString("id")); System.out.println("password : " + rs.getString("password")); System.out.println(""); } } finally { rs.close(); pstmt.close(); con.close();
}
也可以将“//根据参数列表的大小生成in串”和“//根据参数列表设置sql参数”合并,
直接list直接生成最终的sql文,传入pstmt。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 爱快路由器端口更改错误导致无法访问
- ¥20 安装catkin时遇到了如下问题请问该如何解决呢
- ¥15 VAE模型如何输出结果
- ¥15 编译python程序为pyd文件报错:{"source code string cannot contain null bytes"
- ¥20 关于#r语言#的问题:广义加行模型拟合曲线后如何求拐点
- ¥15 fluent设置了自动保存后,会有几个时间点不保存
- ¥20 激光照射到四象线探测器,通过液晶屏显示X、Y值
- ¥50 数据库开发问题求解答
- ¥15 安装anaconda时报错
- ¥15 小程序有个导出到插件方式,我是在分包下引入的插件,这个export的路径对吗,我看官方文档上写的是相对路径