【问题标题】:Why are there double question marks in JDBC code为什么JDBC代码中有双问号
【发布时间】:2013-03-13 18:35:28
【问题描述】:

我正在使用 PHP 将 JDBC sql 语句转换为 ODBC/DB2。我遇到了以下让我感到困惑的条款。

WHERE phid = ??id

我的第一直觉是它是用于准备好的陈述,但现在我不太确定。这是 JSP/JDBC 的事情吗? Google/stack 没有发现任何东西。

【问题讨论】:

  • 你能把找到这个的代码块贴出来吗?
  • 这不是标准 JDBC,可能是供应商特定的扩展。
  • 或者它可能是一些特定于应用程序(命名)的参数处理。
  • 你能发布更多的java代码吗?完整的 sql 准备语句和任何 setString 调用它。

标签: java sql jdbc


【解决方案1】:

哇! 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

【讨论】:

    【解决方案2】:

    正如其他人所评论的(抱歉,还没有足够的代表发表评论),这可能是命名参数处理的某种方式。我在 JDBC 和我知道的任何 ORM 框架中都找不到对它的任何引用,因此它可能是为该特定应用程序创建的自定义 JDBC/ORM 框架。查看更多示例代码肯定会有所帮助。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2013-06-03
      • 2023-01-15
      • 2011-08-21
      • 2022-01-23
      • 2021-01-06
      • 2019-05-30
      相关资源
      最近更新 更多