(oracle)SELECT(即returns不止一行)里面的DECODE
(oracle) SELECT (that returns more than one row) inside DECODE
我正在尝试编写一个包含 SELECT 的 DECODE 语句,它看起来像这样:
SELECT DECODE(A.name, (SELECT name FROM B WHERE id IN (1000,1001)),'Value1','Value2') FROM A
显然,如果我的 select 语句在 DECODE returns 中超过一行,我将得到一个异常 "ORA-01427: single-row subquery returns more than one row"。这很公平。
我希望在那里得到不止一行,这就是目的,我需要为所有匹配 A.name 的项目显示 Value1,为不匹配的项目显示 Value2。类似于 foreach 循环,但在 DECODE 内部。
正确的做法是什么?
更新:
Table答:
+--------------+--------+
|Surname | Name |
+--------------+--------+
| Abc| John |
| Smith| Piter |
| Cook| Ann |
+--------------+--------+
Table乙:
+--------------+--------+
|ID | Name |
+--------------+--------+
| 1000| John |
| 1001| Piter |
| 2003| Ann |
+--------------+--------+
我希望看到的:
值 1
值 1
值 2
在这种情况下,您可以使用 CASE 语句:
SELECT
CASE WHEN
a.name in (select name from b where id in (1000, 1001)) then 'Value1'
ELSE 'Value2'
END
FROM a;
您可以使用内部联接解决此问题:
-- Test case setup
CREATE TABLE A(SURNAME, NAME) AS
SELECT 'Abc', 'John' FROM DUAL UNION ALL
SELECT 'Smith', 'Piter' FROM DUAL UNION ALL
SELECT 'Cook', 'Ann' FROM DUAL;
CREATE TABLE B(ID, NAME) AS
SELECT 1001, 'John' FROM DUAL UNION ALL
SELECT 1002, 'Piter' FROM DUAL UNION ALL
SELECT 2003, 'Ann' FROM DUAL;
-- Solution
SELECT CASE WHEN B.ID IN (1001, 1002)
THEN 'Value1'
ELSE 'Value2'
END Value
FROM A, B
WHERE A.NAME = B.NAME
结果:
VALUE
------
Value1
Value1
Value2
我正在尝试编写一个包含 SELECT 的 DECODE 语句,它看起来像这样:
SELECT DECODE(A.name, (SELECT name FROM B WHERE id IN (1000,1001)),'Value1','Value2') FROM A
显然,如果我的 select 语句在 DECODE returns 中超过一行,我将得到一个异常 "ORA-01427: single-row subquery returns more than one row"。这很公平。
我希望在那里得到不止一行,这就是目的,我需要为所有匹配 A.name 的项目显示 Value1,为不匹配的项目显示 Value2。类似于 foreach 循环,但在 DECODE 内部。
正确的做法是什么?
更新: Table答:
+--------------+--------+
|Surname | Name |
+--------------+--------+
| Abc| John |
| Smith| Piter |
| Cook| Ann |
+--------------+--------+
Table乙:
+--------------+--------+
|ID | Name |
+--------------+--------+
| 1000| John |
| 1001| Piter |
| 2003| Ann |
+--------------+--------+
我希望看到的:
值 1
值 1
值 2
在这种情况下,您可以使用 CASE 语句:
SELECT
CASE WHEN
a.name in (select name from b where id in (1000, 1001)) then 'Value1'
ELSE 'Value2'
END
FROM a;
您可以使用内部联接解决此问题:
-- Test case setup
CREATE TABLE A(SURNAME, NAME) AS
SELECT 'Abc', 'John' FROM DUAL UNION ALL
SELECT 'Smith', 'Piter' FROM DUAL UNION ALL
SELECT 'Cook', 'Ann' FROM DUAL;
CREATE TABLE B(ID, NAME) AS
SELECT 1001, 'John' FROM DUAL UNION ALL
SELECT 1002, 'Piter' FROM DUAL UNION ALL
SELECT 2003, 'Ann' FROM DUAL;
-- Solution
SELECT CASE WHEN B.ID IN (1001, 1002)
THEN 'Value1'
ELSE 'Value2'
END Value
FROM A, B
WHERE A.NAME = B.NAME
结果:
VALUE
------
Value1
Value1
Value2