繁体   English   中英

如何合并同一列的SQL查询?

[英]How to combine SQL queries for same column?

我已搜索但未找到有关我的特定问题的任何示例。

我正在尝试从包含部门名称的列中删除一些不需要的文本。 我试图结合2个查询来执行此操作。

此第一个查询将删除名称中冒号后的所有字符:

SELECT
CASE WHEN CHARINDEX(':', DB.Table.DEPT)>0 
THEN
LEFT(DB.Table.DEPT, CHARINDEX(':', DB.Table.DEPT)-1) 
ELSE 
DB.Table.DEPT
END
FROM
DB.Table

第二个查询从名称中删除前缀:

SELECT
REPLACE(
REPLACE(
REPLACE (DB.Table.DEPT,'[NA1] ','') 
,'[NA2] ', '')
,'[NA3] ', '')
FROM
DB.Table

两者都很好地相互独立运行,但是当我尝试将它们组合在一起时会失败。

SELECT
CASE WHEN CHARINDEX(':', DB.Table.DEPT)>0 
THEN
LEFT(DB.Table.DEPT, CHARINDEX(':', DB.Table.DEPT)-1) 
ELSE 
DB.Table.DEPT
END
FROM
(SELECT
REPLACE(
REPLACE(
REPLACE (DB.Table.DEPT,'[NA1] ','') 
,'[NA2] ', '')
,'[NA3] ', '')
FROM
DB.Table)

我真的可以为此使用一些指导。 提前致谢。

您的查询在语法上是不正确的,因为您需要为子查询和表达式结果使用别名:

SELECT (CASE WHEN CHARINDEX(':', DEPT)>0 
             THEN LEFT(DEPT, CHARINDEX(':', DEPT)-1) 
             ELSE DEPT
        END)
FROM (SELECT REPLACE(REPLACE(REPLACE(t.DEPT,'[NA1] ',''
                                    ), '[NA2] ', ''
                            ), '[NA3] ', ''
                    ) as DEPT
      FROM DB.Table t
     ) t;

编辑:

要同时查看原始部门和新部门:

SELECT (CASE WHEN CHARINDEX(':', new_DEPT) > 0 
             THEN LEFT(new_DEPT, CHARINDEX(':', newj_DEPT)-1) 
             ELSE new_DEPT
        END),
        Orig_DEPT
FROM (SELECT REPLACE(REPLACE(REPLACE(t.DEPT,'[NA1] ',''
                                    ), '[NA2] ', ''
                            ), '[NA3] ', ''
                    ) as new_DEPT,
             t.DEPT as orig_DEPT
      FROM DB.Table t
     ) t

您应该始终为子查询命名。

尝试这个:

SELECT
    CASE WHEN CHARINDEX(':', x.DEPT)>0 
    THEN
        LEFT(x.DEPT, CHARINDEX(':', x.DEPT)-1) 
    ELSE 
        x.DEPT
    END AS DEPT
FROM
(
    SELECT
        REPLACE(REPLACE(REPLACE (DEPT,'[NA1] ','') ,'[NA2] ', ''),'[NA3] ', '') AS DEPT
    FROM
    DB.Table
) x

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM