声明表,插入表中,选择不同的

时间:2019-04-22 17:22:29

标签: sql-server tsql duplicates sql-insert

我有一个表值函数,其中声明了多个表,最后将它们连接在一起以使用每个表中的数据创建最终表。我在重复项方面遇到了问题,所以我创建了一个新表@ORDERHEADER,因此请选择不同的值,然后将其插入表中,最后插入最终表中。当我单独运行select时,它会正确填充,但是当我运行带有插入的选择时,则不会填充任何东西。

下面是我当前正在使用的代码(我保留了注释行,以便您查看尝试使用的代码-第一个“ --LEFT OUTER JOIN”上方是我的工作代码)。

DECLARE @ORDERHEADER TABLE(
    [DIV_CD] [varchar](8) NULL,
    [SALES_ORD_NR] [varchar](8) NOT NULL,
    [CUST_EDP_ID] [decimal](28,0) NOT NULL,
    [OFFER_CD] [varchar] (8) NULL)

    INSERT INTO @ORDERHEADER
    SELECT DISTINCT(SV_OR_1000_ORDER_HEADER.SALES_ORD_NR), 
SV_OR_1000_ORDER_HEADER.DIV_CD, SV_OR_1000_ORDER_HEADER.CUST_EDP_ID, 
SV_OR_1000_ORDER_HEADER.OFFER_CD
    from SV_OR_1000_ORDER_HEADER
    --join @RETURNS r on SV_OR_1000_ORDER_HEADER.SALES_ORD_NR = 
--r.SALES_ORD_NR
                --LEFT OUTER JOIN 
--OPENQUERY(CH1KNOWAPP,'SELECT DISTINCT SALES_ORD_NR FROM 
--EmailVPN..EB_RETURN_CONFIRMATION_NEW WITH(NOLOCK) WHERE 
--ORD_ITM_STA_LGCY_CD IN (''R'',''E'',''4'')') as RET_EMAILS on 
--RET_EMAILS.SALES_ORD_NR COLLATE SQL_Latin1_General_CP1_CI_AS = 
--SV_OR_1000_ORDER_HEADER.SALES_ORD_NR
    --join @RETURNS r on SV_OR_1000_ORDER_HEADER.SALES_ORD_NR = 
--r.SALES_ORD_NR
     --join SV_MACORD_RETURNS on 
--SV_OR_1000_ORDER_HEADER.SALES_ORD_NR = SV_MACORD_RETURNS.SALES_ORD_NR
    -- where exists (SELECT DISTINCT * from 
--SV_OR_1000_ORDER_HEADER)-- exists (select * from SV_OR_1000_ORDER_HEADER 
--join SV_MACORD_RETURNS on SV_OR_1000_ORDER_HEADER.SALES_ORD_NR = 
--SV_MACORD_RETURNS.SALES_ORD_NR) 
    --where SV_OR_1000_ORDER_HEADER.SALES_ORD_NR is not null
    --where  SV_OR_1000_ORDER_HEADER.OFFER_CD not in ('36')

    where SV_OR_1000_ORDER_HEADER.SALES_ORD_NR = 'W3151536'
    --group by SV_MACORD_RETURNS.SALES_ORD_NR,  SV_MACORD_RETURNS.DIVISION, --SV_OR_1000_ORDER_HEADER.CUST_EDP_ID, SV_MACORD_RETURNS.OFFER_CD
    --having COUNT(SV_OR_1000_ORDER_HEADER.SRC_SYS_TRANS_DT) < 2

1 个答案:

答案 0 :(得分:0)

以这种方式测试... 您可以这样编写查询:

SELECT DISTINCT (SV_OR_1000_ORDER_HEADER.SALES_ORD_NR), SV_OR_1000_ORDER_HEADER.DIV_CD, SV_OR_1000_ORDER_HEADER.CUST_EDP_ID, SV_OR_1000_ORDER_HEADER.OFFER_CD
Into #t
from SV_OR_1000_ORDER_HEADER
where SV_OR_1000_ORDER_HEADER.SALES_ORD_NR = 'W3151536'

然后通过其他表完美连接...

您可以在会话中使用#table,并在临时表上工作,而不是在变量表上工作。

查询结束时需要:

 Drop table #t

实际上,您不需要放表就可以了。