1

这是我的查询:

SELECT * FROM Auta WHERE SUBSTR(spz, 1, 2) = 
(SELECT SUBSTR(spz, 1, 2) FROM Auta WHERE typ = 'BMW' AND specifikacia_typu = 'Z1' LIMIT 1);

当我运行它时,我得到了这个错误:

ORA-00907: missing right parenthesis

我有点绝望,我已经尝试在查询中的任何地方添加括号,但我仍然得到错误?查询中有 3 个左括号和 3 个右括号,所以一切都应该没问题。

4

3 回答 3

8

Oracle 中不存在 LIMIT 子句。相反,您将使用 rownum:

SELECT *
  FROM Auta
 WHERE SUBSTR(spz, 1, 2) = (SELECT SUBSTR(spz, 1, 2)
                              FROM Auta
                             WHERE typ = 'BMW'
                               AND specifikacia_typu = 'Z1'
                               AND ROWNUM = 1);
于 2009-10-07T21:28:26.280 回答
4

“LIMIT 1”是干什么用的?我不相信这是正确的 Oracle 语法。如果您试图将输出限制为一行,请使用:

WHERE rownum = 1

于 2009-10-07T21:29:24.500 回答
4

据我所知,LIMIT 1 是 MySQL 主义。

  SELECT *
    FROM Auta
   WHERE SUBSTR(spz, 1, 2) =
         (SELECT SUBSTR(spz, 1, 2)
          FROM Auta
         WHERE typ = 'BMW'
           AND specifikacia_typu = 'Z1'
           AND ROWNUM = 1);

...应该给你预期的结果

于 2009-10-07T21:34:23.913 回答