簡體   English   中英

在一個SQL Server存儲過程中包括INSERT和UPDATE查詢

[英]Include both INSERT and UPDATE queries in one SQL Server stored procedure

我正在嘗試在SQL Server 2008中的一個存儲過程中執行INSERTUPDATE 。當我分別執行UPDATE查詢和INSERT查詢時,它們工作正常。 但是,當我嘗試將它們包含在一個存儲過程中時,出現語法錯誤。

這是我的存儲過程:

SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

IF object_ID(N'[dbo].[usp_AtRiskAsset_SFLoadStaging]') IS NOT NULL
      DROP PROCEDURE [dbo ].[usp_AtRiskAsset_SFLoadStaging]
GO

CREATE PROCEDURE [dbo].[usp_AtRiskAsset_SFLoadStaging]
AS
BEGIN
    INSERT INTO dbo.ARA_Stage (Id, [CanceledRevenue], [YearToDateRevenue], [PriorYearRevenue])
        SELECT
            ARA.[Id],
            'NULL',
            'NULL',
            'NULL'
        FROM 
            dbo.ARA ARA
        INNER JOIN 
            dbo.Asset AST ON AST.[Id] = ARA.Asset__c
        INNER JOIN 
            dbo.[Case] CS ON CS.[Id] = ARA.Case__c
        WHERE 
            CS.IsClosed = 'false' 
            AND CS.Record_Type_Name__c = 'At Risk'
            AND AST.IsActive__c = 'true'

    UPDATE dbo.ARA_Stage
        SELECT 
            ARS.Id,
            ARW.CanceledRevenue,
            ARW.YearToDateRevenue,  
            ARW.PriorYearRevenue
        FROM 
            dbo.ARA_Working ARW
        INNER JOIN 
            dbo.Account AC ON ARW.AccountNumber =  AC.Contract_Number__c
        INNER JOIN 
            dbo.Asset AST ON ARW.PDCT01_ID = AST.PDCT01_Id__c
                          AND AST.AccountId = AC.Id
        INNER JOIN 
            dbo.ARA ARS ON AST.Id = ARS.Asset__C
        INNER JOIN 
            dbo.Product2 PRD ON ARW.PDCT01_ID = PRD.PDCT01_Id__c
                             AND AST.PDCT01_Id__c = ARW.PDCT01_ID
        INNER JOIN 
            [dbo].[Case] CS ON ARS.Case__c = CS.Id
        WHERE  
            CS.Account_Contract_Number__c = ARW.AccountNumber
            AND CS.Record_Type_Name__c = 'At Risk'
            AND CS.IsClosed = 'false'
END
GO

基本上,我需要從所有記錄的“階段”表中清除收入值,然后從工作表中更新收入值。 查詢可以單獨正常運行,但是當我在SQL Server中運行時,出現以下錯誤。

消息156,級別15,狀態1,過程usp_AtRiskAsset_SFLoadStaging,第46行
關鍵字“ SELECT”附近的語法不正確。

有人可以幫忙嗎?

您需要映射set by update關鍵字中select中的列

例如

UPDATE dbo.ARA_Stage
SET [CanceledRevenue] = ARW.CanceledRevenue
...

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM