Sql (oracle)选择(返回多行)内部解码

Sql (oracle)选择(返回多行)内部解码,sql,oracle,decode,Sql,Oracle,Decode,我正在尝试编写一个包含SELECT的DECODE语句,它将如下所示: SELECT DECODE(A.name, (SELECT name FROM B WHERE id IN (1000,1001)),'Value1','Value2') FROM A 显然,如果DECODE中的select语句返回多行,我将得到一个异常“ORA-01427:单行子查询返回多行”。这很公平 我希望得到不止一行,这就是目的,我需要为所有与A.name匹配的项显示Value1,为那些不匹配的项显示Value2。像

我正在尝试编写一个包含SELECT的DECODE语句,它将如下所示:

SELECT DECODE(A.name, (SELECT name FROM B WHERE id IN (1000,1001)),'Value1','Value2') FROM A
显然,如果DECODE中的select语句返回多行,我将得到一个异常“ORA-01427:单行子查询返回多行”。这很公平

我希望得到不止一行,这就是目的,我需要为所有与A.name匹配的项显示Value1,为那些不匹配的项显示Value2。像foreach循环,但内部解码

什么是正确的做法

更新: 表A:

表B:

+--------------+--------+
|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

请显示表定义、示例数据和预期输出。请显示完整查询。A和B是什么?它们之间有什么关系吗?B中可以有多行同名吗?Aleksej,没有。我稍后会提供更多详细信息,以使问题更清楚-带有表格示例和预期结果。这正是我需要的,谢谢!工作得很好。
VALUE
------
Value1
Value1
Value2