JDBC PreparedStatement setString IN 传多个参数

本文探讨了在使用JDBC PreparedStatement处理SQL的IN条件时遇到的问题。错误方式是将多个值拼接成一个字符串传入,导致查询结果不正确。测试未通过的原因在于不同Oracle驱动对这种情况的处理不一致,可能出现异常。正确的做法是为每个参数使用单独的?占位符。示例代码展示了正确设置多个参数的方法,并显示了成功的输出结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在使用JDBC PreparedStatement 进行SQL预编译时,发现使用IN(String) 传入一个字符串(逗号为分隔符),查询结果不正确。

以下面SQL为例,进行测试。

SELECT * FROM EMP T WHERE T.ENAME IN ('BLAKE', 'ADAMS')

Java中通过 ? 占位符传参。

错误的方式:

直接传入一个拼接字符串。因为会把拼接的字符串当作一个元素去查询。

测试未通过的方式:

PreparedStatement statement = connection.prepareStatement("Select * from test where field in (?)");
Array array = statement.getConnection().createArrayOf("VARCHAR", new Object[]{"A1", "B2","C3"});
statement.setArray(1, array);
ResultSet rs = statement.executeQuery();
Array array = statement.getConnection().createArrayOf("VARCHAR", new Object[]{"A1", "B2","C3"});

上面这句,在执行过程中会出现异常,不同的Oracle驱动架包提示的信息不一样,主要使用了 classes12.jar、ojdbc6.jar、ojdbc14.jar进行了测试。JDK使用了JDK1.6和JDK8。

正确的方式(测试通过):

IN里面有几个参数,就添加几个占位符。完整代码如下:

package com.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

public class TestJdbc {
	/**
	 * @param args
	 * @throws Exception 
	 */
	public static void main(String[] args) throws Exception{
		String url="jdbc:oracle:thin:@127.0.0.1:1521:orcl";
		String username="scott";
		String password="scott";
		Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
		Connection con=DriverManager.getConnection(url,username,password);
		String ename[]=new String[]{"BLAKE","ADAMS"};
		StringBuilder builder=new StringBuilder();
		for(int i=0;i<ename.length;i++){
			if(i==0){
				builder.append("?");
			}
			else{
				builder.append(",?");
			}
		}
		String sql="select * from EMP t WHERE t.ENAME IN("+builder.toString()+")";
		PreparedStatement pst=con.prepareStatement(sql);
		int index=1;
		for(String o : ename){
			pst.setString(index++,o);
		}
		ResultSet rs=pst.executeQuery();
		while(rs.next()){
			System.out.println(rs.getString("ENAME"));
		}
	}
}

输出结果如下:

BLAKE
ADAMS

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值