簡體   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