哇! Mabye 它只是一个普通的绑定变量,但连续有 2 个! java.sql.Conneciton(快速阅读)的文档中没有任何内容说它们必须用空格分隔。请发布更多代码,以便我们查看是否有任何 setString 调用来添加绑定变量。
例如,像这样的:
pstmt = conn.prepareStatement("select blah from blah WHERE phid = ??id and blah blah");
pstmt.setString(1, "customer_");
pstmt.setString(2, "order_");
我从未见过这样的事情,但也许这就是他们正在做的事情?
编辑:我试过了!它给了我一个错误!我想知道你是否发现了一些死代码?这是我尝试过的:
sql.append("SELECT A.ID, A.GROUP_NUMBER, A.GROUP_NAME ");
sql.append("FROM " + tab1 + " A ");
sql.append("INNER JOIN " + tab2 + " B ");
sql.append("ON (A.ID = B.GROUP_ID) ");
sql.append("WHERE B.THREAD_ID = ? ");
sql.append("AND B.THREAD_ID = ??ID ");
sql.append("ORDER BY A.ID ");
// ...
conn = getConn();
pstmt = conn.prepareStatement(sql.toString());
pstmt.setInt(1, threadId);
pstmt.setString(2, "B.");
pstmt.setString(3, "THREAD_");
我收到了这个错误:
ILLEGAL SYMBOL "?". SOME SYMBOLS THAT MIGHT BE LEGAL ARE: MICROSECONDS MICROSECOND SECONDS SECOND MINUTES MINUTE HOURS. SQLCODE=-104, SQLSTATE=42601, DRIVER=3.57.82