Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8837665
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 14, 20262026-06-14T09:47:08+00:00 2026-06-14T09:47:08+00:00

I want to merge two tables using SQL Server on the following basis: IF

  • 0

I want to merge two tables using SQL Server on the following basis:

IF the primary key (Operation) matches THEN
    If Source Date Matches Target Date
        Do nothing
    Else
        SET Target Revised_Date to Source Date
Else
    Insert Target Row from Source Row

I have built an SQL merge below that does the first stage but can’t see how to do the second stage.

MERGE 
    Completed_Operations AS target
USING 
    @Completed_Operation_Table AS source ON (target.Operation = source.Operation)
WHEN MATCHED THEN 
    UPDATE 
    SET target.Revised_Completion_Date  = source.Completion_Date,
            target.Revised_Pln_Hrs          = source.Pln_Hrs,
            target.Revised_Pln_Hrs_Capped   = source.Pln_Hrs_Capped,
            target.Revised_Act_Hrs          = source.Act_Hrs
WHEN NOT MATCHED THEN   
    INSERT (Operation, Orig_Completion_Date, Orig_Pln_Hrs, Orig_Act_Hrs, Revised_Completion_Date, Revised_Pln_Hrs, Revised_Act_Hrs)
    VALUES (source.Operation, source.Completion_Date, source.Pln_Hrs, source.Act_Hrs, NULL, NULL, NULL);
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-14T09:47:09+00:00Added an answer on June 14, 2026 at 9:47 am

    In a WHEN clause it is possible to add additional condition

    MERGE
    Completed_Operations AS target
    USING 
    @Completed_Operation_Table AS source ON (target.Operation = source.Operation)
    WHEN MATCHED AND (source.Date <> target.Date) THEN
      UPDATE 
        SET target.Revised_Completion_Date  = source.Completion_Date,
            target.Revised_Pln_Hrs          = source.Pln_Hrs,
            target.Revised_Pln_Hrs_Capped   = source.Pln_Hrs_Capped,
            target.Revised_Act_Hrs          = source.Act_Hrs
    WHEN NOT MATCHED THEN
      INSERT (Operation, Orig_Completion_Date, Orig_Pln_Hrs, Orig_Act_Hrs, Revised_Completion_Date, Revised_Pln_Hrs, Revised_Act_Hrs)
      VALUES (source.Operation, source.Completion_Date, source.Pln_Hrs, source.Act_Hrs, NULL, NULL, NULL);
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I've been using the MERGE operation in SQL Server 2008, but have now come
I have two mysql tables and i want to merge the results of these
I want to merge two cells in excel using pyExcelerator , ws.write_merge(r1=0,r2=1,c1=0, c2=0, label='test1',
I'm using classic ASP in my project. I want to merge two XMLs together.
I am using SQL Server 2008 Enterprise DB and using the new Merge statement
I want to create a merge that will compare two tables and insert not
I have two tables, each one has a primary ID column as key. I
I have two tables with identical structures handling distinct data. I want to merge
Is there a way to merge two primary keys into one and then cascade
Possible Duplicate: How can I merge two MySql tables? I want to merge multiple

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.