Oracle SQL 由 ORDER BY 引起的子查询语法错误
Oracle SQL Subquery Syntax Error caused by ORDER BY
我在 Oracle SQL 查询中遇到语法错误。查询应该让我知道员工的部门。如果员工没有部门(null),我想要层次结构中第一个经理的部门,该部门有一个部门。
SELECT department_id FROM department
WHERE department_id =
(
SELECT department_id FROM employee
WHERE department_id IS NOT NULL AND rownum = 1
start WITH employee_id = 19
connect by employee_id = prior manager_id
ORDER BY level
);
错误信息是这样的:
ORA-00907: missing right parenthesis
00907. 00000 - "missing right parenthesis"
*Cause:
*Action:
Error at Line: 8 Column: 2
我已经编写了一个替代查询,它可以完成这项工作。但是我不是很满意。
SELECT department_id FROM department
WHERE department_id =
(
SELECT department_id FROM employee
WHERE level =
(
SELECT MIN(level) FROM employee
WHERE department_id IS NOT NULL
start WITH employee_id = 19
connect by employee_id = prior manager_id
)
start WITH employee_id = 19
connect by employee_id = prior manager_id
);
您知道如何解决第一个查询吗?或者简化第二个?
先感谢您。
在您的第一个查询中,@Barbaros 正确地说,不需要 ORDER BY
,甚至 rownum = 1
也不会按照您的想法进行。
以下查询是否满足您的要求:
SELECT
E.EMPLOYEE_ID,
CASE WHEN E.DEPARTMENT_ID IS NOT NULL
THEN E.DEPARTMENT_ID
ELSE LAG(D.DEPARTMENT_ID IGNORE NULLS) OVER(ORDER BY LEVEL)
END AS DEPARTMENT_ID
FROM
EMPLOYEE E
LEFT JOIN DEPARTMENT D ON E.DEPARTMENT_ID = D.DEPARTMENT_ID
START WITH E.EMPLOYEE_ID = 19
CONNECT BY E.EMPLOYEE_ID = PRIOR E.MANAGER_ID
干杯!!
我在 Oracle SQL 查询中遇到语法错误。查询应该让我知道员工的部门。如果员工没有部门(null),我想要层次结构中第一个经理的部门,该部门有一个部门。
SELECT department_id FROM department
WHERE department_id =
(
SELECT department_id FROM employee
WHERE department_id IS NOT NULL AND rownum = 1
start WITH employee_id = 19
connect by employee_id = prior manager_id
ORDER BY level
);
错误信息是这样的:
ORA-00907: missing right parenthesis
00907. 00000 - "missing right parenthesis"
*Cause:
*Action:
Error at Line: 8 Column: 2
我已经编写了一个替代查询,它可以完成这项工作。但是我不是很满意。
SELECT department_id FROM department
WHERE department_id =
(
SELECT department_id FROM employee
WHERE level =
(
SELECT MIN(level) FROM employee
WHERE department_id IS NOT NULL
start WITH employee_id = 19
connect by employee_id = prior manager_id
)
start WITH employee_id = 19
connect by employee_id = prior manager_id
);
您知道如何解决第一个查询吗?或者简化第二个? 先感谢您。
在您的第一个查询中,@Barbaros 正确地说,不需要 ORDER BY
,甚至 rownum = 1
也不会按照您的想法进行。
以下查询是否满足您的要求:
SELECT
E.EMPLOYEE_ID,
CASE WHEN E.DEPARTMENT_ID IS NOT NULL
THEN E.DEPARTMENT_ID
ELSE LAG(D.DEPARTMENT_ID IGNORE NULLS) OVER(ORDER BY LEVEL)
END AS DEPARTMENT_ID
FROM
EMPLOYEE E
LEFT JOIN DEPARTMENT D ON E.DEPARTMENT_ID = D.DEPARTMENT_ID
START WITH E.EMPLOYEE_ID = 19
CONNECT BY E.EMPLOYEE_ID = PRIOR E.MANAGER_ID
干杯!!