日期:2014-05-18  浏览次数:20778 次

SQLServerException: 索引 1 超出范围。
正在写一个用JAVA与SQL数据库通信的程序,用到PreparedStatement。相关的代码段是这样的
		 String StrSql ="insert into mem_server (id,typeid,ip,community) values ('?','?','?','?')";
         String [] aStrParams = new String[4];
 aStrParams[0] = (inMap.get("A")).replaceAll(" ", "");
 aStrParams[1] = (inMap.get("B")).replaceAll(" ", "");
 aStrParams[2] = (inMap.get("C")).replaceAll(" ", "");
 aStrParams[3] = (inMap.get("D")).replaceAll(" ", "");
         sqlvisit.UpdateSQL(StrSql, aStrParams);

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
	public int UpdateSQL(String sSQL, String[] sParams) {
int result = 0;

try {
PreparedStatement ps = _CONN.prepareStatement(sSQL);
if (sParams != null) {
for (int i = 0; i < sParams.length; i++) {
ps.setString(i + 1, sParams[i]);
}
}
result = ps.executeUpdate();
} catch (Exception ex) {
ex.printStackTrace();
System.out.println(ex.getMessage());
} finally {
//CloseConn();
}
return result;
}

运行完代码之后提示错误:com.microsoft.sqlserver.jdbc.SQLServerException: 索引 1 超出范围。
我看到我的?是英文的,4个,与输入的sParams数量相同。但是还为什么会有这个错误呢?
另外,我把
values ('?','?','?','?')
改为
values (?,?,?,?)
之后程序虽然不报错了,但是数据库中却没有输入进去。

请问大侠们这是为什么涅
------解决方案--------------------
你用问号占位为什么要给问号加单引号啊?没见过你这种写法。直接写问号,然后直接setString就行了啊。