Error converting data type varchar to numeric and Conversion failed when converting date and/or time from character string.

  • I'm trying to compare two date ranges of employee data (i.e. 6/1/2018 to 6/4/2018) **within the same table** . I did a self join to the table to compare each column and if the column did not meet criteria then I want it to show NULL.  I've noticed that not all columns are showing NULL when they should be and there are a few rows that are error out due to the following errors:

    1.Conversion failed when converting date and/or time from character string.
      ---WHEN emp1.RECENT_HIRE_DATE <> emp2.RECENT_HIRE_DATE THEN                   emp2.RECENT_HIRE_DATE
      ---WHEN emp1.ORIG_HIRE_DATE <> emp2.ORIG_HIRE_DATE THEN emp2.ORIG_HIRE_DATE

    2. Error converting data type varchar to numeric.
       ---WHEN emp1.HRLY_RATE <> emp2.HRLY_RATE THEN emp2.HRLY_RATE
       ---WHEN emp1.EXPECTED_HOURS <> emp2.EXPECTED_HOURS THEN emp2.EXPECTED_HOURS
    etc.
    The lines commented out below in the code are throwing the error messages.

    Can someone please help with this?  I have tried to CAST / CONVERT the rows, but I obviously have the wrong syntax. The entire SQL query is below.

    select emp1.RRD,emp1.EMP_ID,emp1.JOB_REQ,emp1.POS_NUM,emp1.CANDIDATE_ID,emp1.EMP_STATUS,emp1.WORKER_TYPE,emp1.CONT_SUP_NAME,emp1.REMOTE_FLAG,emp1.emp_NAME,
    emp1.FIRST_NAME,emp1.LAST_NAME,emp1.RECENT_HIRE_DATE,emp1.ORIG_HIRE_DATE,emp1.DEPT_NUM,emp1.DEPT_NAME,emp1.FUNCTIONAL_GROUP,emp1.PAY_TYPE,emp1.JOB_TITLE,
    emp1.JOB_CODE,emp1.JOB_FAMILY,emp1.JOB_GROUP,emp1.JOB_FUNCTION,emp1.WORK_PHONE,emp1.EMAIL,emp1.EMP_MGR_LVL,emp1.ANNUAL_RATE,emp1.HRLY_RATE,emp1.EMP_TYPE,
    emp1.TIME_TYPE,emp1.EXEMPT,emp1.EXPECTED_HOURS,emp1.COMP_GRADE,emp1.WORK_LOC_ID,emp1.WORK_LOC_NAME,emp1.WORK_LOC_ADD_1,emp1.WORK_LOC_ADD_2,emp1.WORK_LOC_CITY,
    emp1.WORK_LOC_STATE,emp1.WORK_LOC_ZIP,emp1.HOME_ADD_1,emp1.HOME_ADD_2,emp1.HOME_ADD_CITY,emp1.HOME_ADD_STATE,emp1.HOME_ADD_ZIP,emp1.HOME_ADD_ST,emp1.LOA,
    emp1.REPORTS_TO,emp1.REPORTS_TO_EMP_ID,emp1.REPORTS_TO_EMAIL,emp1.REPORTS_TO_MGR_LVL,emp1.emp_rank,emp1.MGR_LVL_NUM,emp1.HIERARCHY_TIER,emp1.TIER_1,
    emp1.TIER_2,emp1.TIER_3,emp1.TIER_4,emp1.TIER_5,emp1.TIER_6,emp1.Snapshot_FTE,emp1.Period_FTE,emp1.Info_Source,emp1.Calendar_period,emp2.RRD,emp2.EMP_ID,
    emp2.JOB_REQ,emp2.POS_NUM,emp2.CANDIDATE_ID,emp2.EMP_STATUS,emp2.WORKER_TYPE,emp2.CONT_SUP_NAME,emp2.REMOTE_FLAG,emp2.emp_NAME,emp2.FIRST_NAME,emp2.LAST_NAME,
    emp2.RECENT_HIRE_DATE,emp2.ORIG_HIRE_DATE,emp2.DEPT_NUM,emp2.DEPT_NAME,emp2.FUNCTIONAL_GROUP,emp2.PAY_TYPE,emp2.JOB_TITLE,emp2.JOB_CODE,emp2.JOB_FAMILY,
    emp2.JOB_GROUP,emp2.JOB_FUNCTION,emp2.WORK_PHONE,emp2.EMAIL,emp2.EMP_MGR_LVL,emp2.ANNUAL_RATE,emp2.HRLY_RATE,emp2.EMP_TYPE,emp2.TIME_TYPE,emp2.EXEMPT,
    emp2.EXPECTED_HOURS,emp2.COMP_GRADE,emp2.WORK_LOC_ID,emp2.WORK_LOC_NAME,emp2.WORK_LOC_ADD_1,emp2.WORK_LOC_ADD_2,emp2.WORK_LOC_CITY,emp2.WORK_LOC_STATE,
    emp2.WORK_LOC_ZIP,emp2.HOME_ADD_1,emp2.HOME_ADD_2,emp2.HOME_ADD_CITY,emp2.HOME_ADD_STATE,emp2.HOME_ADD_ZIP,emp2.HOME_ADD_ST,emp2.LOA,emp2.REPORTS_TO,
    emp2.REPORTS_TO_EMP_ID,emp2.REPORTS_TO_EMAIL,emp2.REPORTS_TO_MGR_LVL,emp2.emp_rank,emp2.MGR_LVL_NUM,emp2.HIERARCHY_TIER,emp2.TIER_1,emp2.TIER_2,emp2.TIER_3,
    emp2.TIER_4,emp2.TIER_5,emp2.TIER_6,emp2.Snapshot_FTE,emp2.Period_FTE,emp2.Info_Source,emp2.Calendar_period,

    CASEWHEN emp1.JOB_REQ <> emp2.JOB_REQ THEN emp2.JOB_REQWHEN emp1.POS_NUM <> emp2.POS_NUM THEN emp2.POS_NUMWHEN emp1.CANDIDATE_ID <> emp2.CANDIDATE_ID THEN emp2.CANDIDATE_IDWHEN emp1.EMP_STATUS <> emp2.EMP_STATUS THEN emp2.EMP_STATUSWHEN emp1.WORKER_TYPE <> emp2.WORKER_TYPE THEN emp2.WORKER_TYPEWHEN emp1.CONT_SUP_NAME <> emp2.CONT_SUP_NAME THEN emp2.CONT_SUP_NAMEWHEN emp1.REMOTE_FLAG <> emp2.REMOTE_FLAG THEN emp2.REMOTE_FLAGWHEN emp1.emp_NAME <> emp2.emp_NAME THEN emp2.emp_NAMEWHEN emp1.FIRST_NAME <> emp2.FIRST_NAME THEN emp2.FIRST_NAMEWHEN emp1.LAST_NAME <> emp2.LAST_NAME THEN emp2.LAST_NAME---WHEN emp1.RECENT_HIRE_DATE <> emp2.RECENT_HIRE_DATE THEN emp2.RECENT_HIRE_DATE---WHEN emp1.ORIG_HIRE_DATE <> emp2.ORIG_HIRE_DATE THEN emp2.ORIG_HIRE_DATEWHEN emp1.DEPT_NUM <> emp2.DEPT_NUM THEN emp2.DEPT_NUMWHEN emp1.DEPT_NAME <> emp2.DEPT_NAME THEN emp2.DEPT_NAMEWHEN emp1.FUNCTIONAL_GROUP <> emp2.FUNCTIONAL_GROUP THEN emp2.FUNCTIONAL_GROUPWHEN emp1.PAY_TYPE <> emp2.PAY_TYPE THEN emp2.PAY_TYPEWHEN emp1.JOB_TITLE <> emp2.JOB_TITLE THEN emp2.JOB_TITLEWHEN emp1.JOB_CODE <> emp2.JOB_CODE THEN emp2.JOB_CODEWHEN emp1.JOB_FAMILY <> emp2.JOB_FAMILY THEN emp2.JOB_FAMILYWHEN emp1.JOB_GROUP <> emp2.JOB_GROUP THEN emp2.JOB_GROUPWHEN emp1.JOB_FUNCTION <> emp2.JOB_FUNCTION THEN emp2.JOB_FUNCTIONWHEN emp1.WORK_PHONE <> emp2.WORK_PHONE THEN emp2.WORK_PHONEWHEN emp1.EMAIL <> emp2.EMAIL THEN emp2.EMAILWHEN emp1.EMP_MGR_LVL <> emp2.EMP_MGR_LVL THEN emp2.EMP_MGR_LVL---WHEN emp1.ANNUAL_RATE <> emp2.ANNUAL_RATE THEN emp2.ANNUAL_RATE---WHEN emp1.HRLY_RATE <> emp2.HRLY_RATE THEN emp2.HRLY_RATEWHEN emp1.EMP_TYPE <> emp2.EMP_TYPE THEN emp2.EMP_TYPEWHEN emp1.TIME_TYPE <> emp2.TIME_TYPE THEN emp2.TIME_TYPEWHEN emp1.EXEMPT <> emp2.EXEMPT THEN emp2.EXEMPT---WHEN emp1.EXPECTED_HOURS <> emp2.EXPECTED_HOURS THEN emp2.EXPECTED_HOURSWHEN emp1.COMP_GRADE <> emp2.COMP_GRADE THEN emp2.COMP_GRADEWHEN emp1.WORK_LOC_ID <> emp2.WORK_LOC_ID THEN emp2.WORK_LOC_IDWHEN emp1.WORK_LOC_NAME <> emp2.WORK_LOC_NAME THEN emp2.WORK_LOC_NAMEWHEN emp1.WORK_LOC_ADD_1 <> emp2.WORK_LOC_ADD_1 THEN emp2.WORK_LOC_ADD_1WHEN emp1.WORK_LOC_ADD_2 <> emp2.WORK_LOC_ADD_2 THEN emp2.WORK_LOC_ADD_2WHEN emp1.WORK_LOC_CITY <> emp2.WORK_LOC_CITY THEN emp2.WORK_LOC_CITYWHEN emp1.WORK_LOC_STATE <> emp2.WORK_LOC_STATE THEN emp2.WORK_LOC_STATEWHEN emp1.WORK_LOC_ZIP <> emp2.WORK_LOC_ZIP THEN emp2.WORK_LOC_ZIPWHEN emp1.HOME_ADD_1 <> emp2.HOME_ADD_1 THEN emp2.HOME_ADD_1WHEN emp1.HOME_ADD_2 <> emp2.HOME_ADD_2 THEN emp2.HOME_ADD_2WHEN emp1.HOME_ADD_CITY <> emp2.HOME_ADD_CITY THEN emp2.HOME_ADD_CITYWHEN emp1.HOME_ADD_STATE <> emp2.HOME_ADD_STATE THEN emp2.HOME_ADD_STATEWHEN emp1.HOME_ADD_ZIP <> emp2.HOME_ADD_ZIP THEN emp2.HOME_ADD_ZIPWHEN emp1.HOME_ADD_ST <> emp2.HOME_ADD_ST THEN emp2.HOME_ADD_STWHEN emp1.LOA <> emp2.LOA THEN emp2.LOAWHEN emp1.REPORTS_TO <> emp2.REPORTS_TO THEN emp2.REPORTS_TOWHEN emp1.REPORTS_TO_EMP_ID <> emp2.REPORTS_TO_EMP_ID THEN emp2.REPORTS_TO_EMP_IDWHEN emp1.REPORTS_TO_EMAIL <> emp2.REPORTS_TO_EMAIL THEN emp2.REPORTS_TO_EMAILWHEN emp1.REPORTS_TO_MGR_LVL <> emp2.REPORTS_TO_MGR_LVL THEN emp2.REPORTS_TO_MGR_LVL---WHEN emp1.emp_rank <> emp2.emp_rank THEN emp2.emp_rank---WHEN emp1.MGR_LVL_NUM <> emp2.MGR_LVL_NUM THEN emp2.MGR_LVL_NUM---WHEN emp1.HIERARCHY_TIER <> emp2.HIERARCHY_TIER THEN emp2.HIERARCHY_TIERWHEN emp1.TIER_1 <> emp2.TIER_1 THEN emp2.TIER_1WHEN emp1.TIER_2 <> emp2.TIER_2 THEN emp2.TIER_2WHEN emp1.TIER_3 <> emp2.TIER_3 THEN emp2.TIER_3WHEN emp1.TIER_4 <> emp2.TIER_4 THEN emp2.TIER_4WHEN emp1.TIER_5 <> emp2.TIER_5 THEN emp2.TIER_5WHEN emp1.TIER_6 <> emp2.TIER_6 THEN emp2.TIER_6---WHEN emp1.Snapshot_FTE <> emp2.Snapshot_FTE THEN emp2.Snapshot_FTE---WHEN emp1.Period_FTE <> emp2.Period_FTE THEN emp2.Period_FTEWHEN emp1.Info_Source <> emp2.Info_Source THEN emp2.Info_Source---WHEN emp1.Calendar_period <> emp2.Calendar_period THEN emp2.Calendar_period

    CASE
    WHEN emp1.JOB_REQ <> emp2.JOB_REQ THEN emp2.JOB_REQ
    WHEN emp1.POS_NUM <> emp2.POS_NUM THEN emp2.POS_NUM
    WHEN emp1.CANDIDATE_ID <> emp2.CANDIDATE_ID THEN emp2.CANDIDATE_ID
    WHEN emp1.EMP_STATUS <> emp2.EMP_STATUS THEN emp2.EMP_STATUS
    WHEN emp1.WORKER_TYPE <> emp2.WORKER_TYPE THEN emp2.WORKER_TYPE
    WHEN emp1.CONT_SUP_NAME <> emp2.CONT_SUP_NAME THEN emp2.CONT_SUP_NAME
    WHEN emp1.REMOTE_FLAG <> emp2.REMOTE_FLAG THEN emp2.REMOTE_FLAG
    WHEN emp1.emp_NAME <> emp2.emp_NAME THEN emp2.emp_NAME
    WHEN emp1.FIRST_NAME <> emp2.FIRST_NAME THEN emp2.FIRST_NAME
    WHEN emp1.LAST_NAME <> emp2.LAST_NAME THEN emp2.LAST_NAME
    ---WHEN emp1.RECENT_HIRE_DATE <> emp2.RECENT_HIRE_DATE THEN emp2.RECENT_HIRE_DATE
    ---WHEN emp1.ORIG_HIRE_DATE <> emp2.ORIG_HIRE_DATE THEN emp2.ORIG_HIRE_DATE
    WHEN emp1.DEPT_NUM <> emp2.DEPT_NUM THEN emp2.DEPT_NUM
    WHEN emp1.DEPT_NAME <> emp2.DEPT_NAME THEN emp2.DEPT_NAME
    WHEN emp1.FUNCTIONAL_GROUP <> emp2.FUNCTIONAL_GROUP THEN emp2.FUNCTIONAL_GROUP
    WHEN emp1.PAY_TYPE <> emp2.PAY_TYPE THEN emp2.PAY_TYPE
    WHEN emp1.JOB_TITLE <> emp2.JOB_TITLE THEN emp2.JOB_TITLE
    WHEN emp1.JOB_CODE <> emp2.JOB_CODE THEN emp2.JOB_CODE
    WHEN emp1.JOB_FAMILY <> emp2.JOB_FAMILY THEN emp2.JOB_FAMILY
    WHEN emp1.JOB_GROUP <> emp2.JOB_GROUP THEN emp2.JOB_GROUP
    WHEN emp1.JOB_FUNCTION <> emp2.JOB_FUNCTION THEN emp2.JOB_FUNCTION
    WHEN emp1.WORK_PHONE <> emp2.WORK_PHONE THEN emp2.WORK_PHONE
    WHEN emp1.EMAIL <> emp2.EMAIL THEN emp2.EMAIL
    WHEN emp1.EMP_MGR_LVL <> emp2.EMP_MGR_LVL THEN emp2.EMP_MGR_LVL
    ---WHEN emp1.ANNUAL_RATE <> emp2.ANNUAL_RATE THEN emp2.ANNUAL_RATE
    ---WHEN emp1.HRLY_RATE <> emp2.HRLY_RATE THEN emp2.HRLY_RATE
    WHEN emp1.EMP_TYPE <> emp2.EMP_TYPE THEN emp2.EMP_TYPE
    WHEN emp1.TIME_TYPE <> emp2.TIME_TYPE THEN emp2.TIME_TYPE
    WHEN emp1.EXEMPT <> emp2.EXEMPT THEN emp2.EXEMPT
    ---WHEN emp1.EXPECTED_HOURS <> emp2.EXPECTED_HOURS THEN emp2.EXPECTED_HOURS
    WHEN emp1.COMP_GRADE <> emp2.COMP_GRADE THEN emp2.COMP_GRADE
    WHEN emp1.WORK_LOC_ID <> emp2.WORK_LOC_ID THEN emp2.WORK_LOC_ID
    WHEN emp1.WORK_LOC_NAME <> emp2.WORK_LOC_NAME THEN emp2.WORK_LOC_NAME
    WHEN emp1.WORK_LOC_ADD_1 <> emp2.WORK_LOC_ADD_1 THEN emp2.WORK_LOC_ADD_1
    WHEN emp1.WORK_LOC_ADD_2 <> emp2.WORK_LOC_ADD_2 THEN emp2.WORK_LOC_ADD_2
    WHEN emp1.WORK_LOC_CITY <> emp2.WORK_LOC_CITY THEN emp2.WORK_LOC_CITY
    WHEN emp1.WORK_LOC_STATE <> emp2.WORK_LOC_STATE THEN emp2.WORK_LOC_STATE
    WHEN emp1.WORK_LOC_ZIP <> emp2.WORK_LOC_ZIP THEN emp2.WORK_LOC_ZIP
    WHEN emp1.HOME_ADD_1 <> emp2.HOME_ADD_1 THEN emp2.HOME_ADD_1
    WHEN emp1.HOME_ADD_2 <> emp2.HOME_ADD_2 THEN emp2.HOME_ADD_2
    WHEN emp1.HOME_ADD_CITY <> emp2.HOME_ADD_CITY THEN emp2.HOME_ADD_CITY
    WHEN emp1.HOME_ADD_STATE <> emp2.HOME_ADD_STATE THEN emp2.HOME_ADD_STATE
    WHEN emp1.HOME_ADD_ZIP <> emp2.HOME_ADD_ZIP THEN emp2.HOME_ADD_ZIP
    WHEN emp1.HOME_ADD_ST <> emp2.HOME_ADD_ST THEN emp2.HOME_ADD_ST
    WHEN emp1.LOA <> emp2.LOA THEN emp2.LOA
    WHEN emp1.REPORTS_TO <> emp2.REPORTS_TO THEN emp2.REPORTS_TO
    WHEN emp1.REPORTS_TO_EMP_ID <> emp2.REPORTS_TO_EMP_ID THEN emp2.REPORTS_TO_EMP_ID
    WHEN emp1.REPORTS_TO_EMAIL <> emp2.REPORTS_TO_EMAIL THEN emp2.REPORTS_TO_EMAIL
    WHEN emp1.REPORTS_TO_MGR_LVL <> emp2.REPORTS_TO_MGR_LVL THEN emp2.REPORTS_TO_MGR_LVL
    ---WHEN emp1.emp_rank <> emp2.emp_rank THEN emp2.emp_rank
    ---WHEN emp1.MGR_LVL_NUM <> emp2.MGR_LVL_NUM THEN emp2.MGR_LVL_NUM
    ---WHEN emp1.HIERARCHY_TIER <> emp2.HIERARCHY_TIER THEN emp2.HIERARCHY_TIER
    WHEN emp1.TIER_1 <> emp2.TIER_1 THEN emp2.TIER_1
    WHEN emp1.TIER_2 <> emp2.TIER_2 THEN emp2.TIER_2
    WHEN emp1.TIER_3 <> emp2.TIER_3 THEN emp2.TIER_3
    WHEN emp1.TIER_4 <> emp2.TIER_4 THEN emp2.TIER_4
    WHEN emp1.TIER_5 <> emp2.TIER_5 THEN emp2.TIER_5
    WHEN emp1.TIER_6 <> emp2.TIER_6 THEN emp2.TIER_6
    ---WHEN emp1.Snapshot_FTE <> emp2.Snapshot_FTE THEN emp2.Snapshot_FTE
    ---WHEN emp1.Period_FTE <> emp2.Period_FTE THEN emp2.Period_FTE
    WHEN emp1.Info_Source <> emp2.Info_Source THEN emp2.Info_Source
    ---WHEN emp1.Calendar_period <> emp2.Calendar_period THEN emp2.Calendar_period

    ELSE NULL END

    ELSE NULL
    END

    from emp_main as emp1, emp_main as emp2where emp1.rrd = '2018-06-04' and emp2.rrd = '2018-06-01'and emp1.emp_id = emp2.emp_id;

    from emp_main as emp1, emp_main as emp2
    where emp1.rrd = '2018-06-04' and emp2.rrd = '2018-06-01'
    and emp1.emp_id = emp2.emp_id;

  • small sample of data. period fte column difference is what should show.

    RRDEMP_IDJOB_REQPOS_NUMCANDIDATE_IDEMP_STATUSWORKER_TYPECONT_SUP_NAMEREMOTE_FLAGemp_NAMEFIRST_NAMELAST_NAMERECENT_HIRE_DATEORIG_HIRE_DATEDEPT_NUMDEPT_NAMEFUNCTIONAL_GROUPPAY_TYPESnapshot_FTEPeriod_FTEInfo_SourceCalendar_period
    6/4/2018111NULLP100990NULLActiveEmployeeNULLNULLNAME1FNAME1LNAME111/14/201111/14/2011100Provider RelationsNULLSalary10.0333WD_ACTIVE6/1/2018
    6/4/20181121070864P122752136092ActiveEmployeeNULLNULLNAME2FNAME2LNAME26/24/20136/24/2013101Case ManagementNULLSalary10.0333WD_ACTIVE6/1/2018
    6/4/2018113NULLP112006NULLActiveEmployeeNULLNULLNAME3FNAME3LNAME310/28/201310/28/2013102OperationsNULLSalary10.0333WD_ACTIVE6/1/2018
    6/4/20181141083898P133296703215ActiveEmployeeNULLNULLNAME4FNAME4LNAME41/6/20141/6/2014103Medical ManagementNULLSalary10.0333WD_ACTIVE6/1/2018
    6/1/2018111NULLP100990NULLActiveEmployeeNULLNULLNAME 1FNAME1LNAME111/14/201111/14/2011100Provider RelationsNULLSalary10.1WD_ACTIVE6/1/2018
    6/1/20181121070864P122752136092ActiveEmployeeNULLNULLNAME 2FNAME2LNAME26/24/20136/24/2013101Case ManagementNULLSalary10.1WD_ACTIVE6/1/2018
    6/1/2018113NULLP112006NULLActiveEmployeeNULLNULLNAME 3FNAME3LNAME310/28/201310/28/2013102OperationsNULLSalary10.1WD_ACTIVE6/1/2018
    6/1/20181141083898P133296703215ActiveEmployeeNULLNULLNAME 4FNAME4LNAME41/6/20141/6/2014103Medical ManagementNULLSalary10.1WD_ACTIVE6/1/2018
  • First problem...  You are expecting to use a single CASE statement that involves every column that you are looking to compare, and some of which are dates.
    Whenever you encounter a row where the date is the first column that's different between the two tables, you're going to find that the CASE statement now
    wants to convert ALL the values it has derived so far to date (or possibly datetime) values.   Designing your query to function this way in order to return a value
    from what may be several different data types is a rather bad idea.   One, you'll get this error, because the inclusion of a date value in any part of this comparison
    is going to force the output column to adopt a date (or datetime) data type, due to data type precedence rules.

    Second problem...  Your query is almost unreadable because of formatting.   It's much harder to ferret out a problem with a query of this nature without some
    decent white space hanging around.    Business coding standards often preach the idea that for a SELECT, all the columns being selected must be on their own
    line, or that the width of selected column lines always be limited to some number of characters, typically in the 80 to 100 range.   Some prefer JOINs be segregated
    to a separate line, with the ON clause and each additional condition with it's own line.   Further, those lines are often either indented hierarchically beneath FROM,
    or the JOIN line is lined up with the FROM line, but the ON and all other conditions are indented.   Frequently, all SQL keywords are in UPPER case, with data types
    being all lower case.   Following some portion of those standards for a query you post will usually make it a lot easier for folks here to help out.

    Third problem...  Your sample data is a picture, which would require that someone attempting to run your query transcribe that data into INSERT statements.   Most
    folks here aren't usually so unbusy that they have time for that kind of thing.   Please be sure to provide sample data in a consumable format, which means table
    create statements and INSERT statements for the sample data.   Also critical is to list the expected results, based on the sample data.

    Steve (aka sgmunson) 🙂 🙂 🙂
    Rent Servers for Income (picks and shovels strategy)

  • Thank you Steve. I'm rather new to this, prior using BI apps to report write.  I apologize about the formatting. I am using an existing table derived from many other tables from what I can see. I hope this is a little clearer below.

    1. What would be the preferred solution to compare the same table's columns to itself for two separate dates that have multiple rows for each date the data is ran?
    Would it be to have multiple CASE statements separating out the date, int, numeric, char, varchar?  
    Basically from the above I would be comparing the RRD (run date) data 6/1/18 to the multiple rows of data
    I hope to see something similar to the following if there are differences between the two dates with their columns.
    The difference between the columns of the two dates are the Period_FTE columns and the EMP_STATUS columns
    rrd                  emp_id  Period_FTE  EMP_STATUS     rrd                emp_id   Period_FTE  EMP_STATUS
    2018-06-04    202678  0.0333          On Leave             2018-06-01  202678   0.1000          Active
    2018-06-04    216586  0.0333          On Leave             2018-06-01  216586   0.1000          Active

    2.

    SELECT
    emp1.RRD,emp1.EMP_ID,emp1.JOB_REQ,emp1.POS_NUM,emp1.CANDIDATE_ID,emp1.EMP_STATUS,emp1.WORKER_TYPE,
    emp1.CONT_SUP_NAME,emp1.REMOTE_FLAG,emp1.emp_NAME,emp1.FIRST_NAME,emp1.LAST_NAME,emp1.RECENT_HIRE_DATE,
    emp1.ORIG_HIRE_DATE,emp1.DEPT_NUM,emp1.DEPT_NAME,emp1.FUNCTIONAL_GROUP,emp1.PAY_TYPE,emp1.JOB_TITLE,
    emp1.JOB_CODE,emp1.JOB_FAMILY,emp1.JOB_GROUP,emp1.JOB_FUNCTION,emp1.WORK_PHONE,emp1.EMAIL,emp1.EMP_MGR_LVL,
    emp1.ANNUAL_RATE,emp1.HRLY_RATE,emp1.EMP_TYPE,emp1.TIME_TYPE,emp1.EXEMPT,emp1.EXPECTED_HOURS,emp1.COMP_GRADE,
    emp1.WORK_LOC_ID,emp1.WORK_LOC_NAME,emp1.WORK_LOC_ADD_1,emp1.WORK_LOC_ADD_2,emp1.WORK_LOC_CITY,emp1.WORK_LOC_STATE,
    emp1.WORK_LOC_ZIP,emp1.HOME_ADD_1,emp1.HOME_ADD_2,emp1.HOME_ADD_CITY,emp1.HOME_ADD_STATE,emp1.HOME_ADD_ZIP,
    emp1.HOME_ADD_ST,emp1.LOA,emp1.REPORTS_TO,emp1.REPORTS_TO_EMP_ID,emp1.REPORTS_TO_EMAIL,emp1.REPORTS_TO_MGR_LVL,
    emp1.emp_rank,emp1.MGR_LVL_NUM,emp1.HIERARCHY_TIER,emp1.TIER_1,emp1.TIER_2,emp1.TIER_3,emp1.TIER_4,emp1.TIER_5,
    emp1.TIER_6,emp1.Snapshot_FTE,emp1.Period_FTE,emp1.Info_Source,emp1.Calendar_period,
    emp2.RRD,emp2.EMP_ID,emp2.JOB_REQ, emp2.POS_NUM,emp2.CANDIDATE_ID,emp2.EMP_STATUS,emp2.WORKER_TYPE,emp2.CONT_SUP_NAME,
    emp2.REMOTE_FLAG,emp2.emp_NAME,emp2.FIRST_NAME,emp2.LAST_NAME,emp2.RECENT_HIRE_DATE,emp2.ORIG_HIRE_DATE,emp2.DEPT_NUM,
    emp2.DEPT_NAME,emp2.FUNCTIONAL_GROUP,emp2.PAY_TYPE,emp2.JOB_TITLE,emp2.JOB_CODE,emp2.JOB_FAMILY,
    emp2.JOB_GROUP,emp2.JOB_FUNCTION,emp2.WORK_PHONE,emp2.EMAIL,emp2.EMP_MGR_LVL,emp2.ANNUAL_RATE,
    emp2.HRLY_RATE,emp2.EMP_TYPE,emp2.TIME_TYPE,emp2.EXEMPT,emp2.EXPECTED_HOURS,emp2.COMP_GRADE,
    emp2.WORK_LOC_ID,emp2.WORK_LOC_NAME,emp2.WORK_LOC_ADD_1,emp2.WORK_LOC_ADD_2,emp2.WORK_LOC_CITY,
    emp2.WORK_LOC_STATE,emp2.WORK_LOC_ZIP,emp2.HOME_ADD_1,emp2.HOME_ADD_2,emp2.HOME_ADD_CITY,
    emp2.HOME_ADD_STATE,emp2.HOME_ADD_ZIP,emp2.HOME_ADD_ST,emp2.LOA,emp2.REPORTS_TO,emp2.REPORTS_TO_EMP_ID,
    emp2.REPORTS_TO_EMAIL,emp2.REPORTS_TO_MGR_LVL,emp2.emp_rank,emp2.MGR_LVL_NUM,emp2.HIERARCHY_TIER,
    emp2.TIER_1,emp2.TIER_2,emp2.TIER_3,emp2.TIER_4,emp2.TIER_5,emp2.TIER_6,emp2.Snapshot_FTE,emp2.Period_FTE,emp2.Info_Source,emp2.Calendar_period,

    CASE

    WHEN emp1.JOB_REQ <> emp2.JOB_REQ THEN emp2.JOB_REQ
    WHEN emp1.POS_NUM <> emp2.POS_NUM THEN emp2.POS_NUM
    WHEN emp1.CANDIDATE_ID <> emp2.CANDIDATE_ID THEN emp2.CANDIDATE_ID
    WHEN emp1.EMP_STATUS <> emp2.EMP_STATUS THEN emp2.EMP_STATUS
    WHEN emp1.WORKER_TYPE <> emp2.WORKER_TYPE THEN emp2.WORKER_TYPE
    WHEN emp1.CONT_SUP_NAME <> emp2.CONT_SUP_NAME THEN emp2.CONT_SUP_NAME
    WHEN emp1.REMOTE_FLAG <> emp2.REMOTE_FLAG THEN emp2.REMOTE_FLAG
    WHEN emp1.emp_NAME <> emp2.emp_NAME THEN emp2.emp_NAME
    WHEN emp1.FIRST_NAME <> emp2.FIRST_NAME THEN emp2.FIRST_NAME
    WHEN emp1.LAST_NAME <> emp2.LAST_NAME THEN emp2.LAST_NAME
    ---WHEN emp1.RECENT_HIRE_DATE <> emp2.RECENT_HIRE_DATE THEN emp2.RECENT_HIRE_DATE
    ---WHEN emp1.ORIG_HIRE_DATE <> emp2.ORIG_HIRE_DATE THEN emp2.ORIG_HIRE_DATE
    WHEN emp1.DEPT_NUM <> emp2.DEPT_NUM THEN emp2.DEPT_NUM
    WHEN emp1.DEPT_NAME <> emp2.DEPT_NAME THEN emp2.DEPT_NAME
    WHEN emp1.FUNCTIONAL_GROUP <> emp2.FUNCTIONAL_GROUP THEN emp2.FUNCTIONAL_GROUP
    WHEN emp1.PAY_TYPE <> emp2.PAY_TYPE THEN emp2.PAY_TYPE
    WHEN emp1.JOB_TITLE <> emp2.JOB_TITLE THEN emp2.JOB_TITLE
    WHEN emp1.JOB_CODE <> emp2.JOB_CODE THEN emp2.JOB_CODE
    WHEN emp1.JOB_FAMILY <> emp2.JOB_FAMILY THEN emp2.JOB_FAMILY
    WHEN emp1.JOB_GROUP <> emp2.JOB_GROUP THEN emp2.JOB_GROUP
    WHEN emp1.JOB_FUNCTION <> emp2.JOB_FUNCTION THEN emp2.JOB_FUNCTION
    WHEN emp1.WORK_PHONE <> emp2.WORK_PHONE THEN emp2.WORK_PHONE
    WHEN emp1.EMAIL <> emp2.EMAIL THEN emp2.EMAIL
    WHEN emp1.EMP_MGR_LVL <> emp2.EMP_MGR_LVL THEN emp2.EMP_MGR_LVL
    ---WHEN emp1.ANNUAL_RATE <> emp2.ANNUAL_RATE THEN emp2.ANNUAL_RATE
    ---WHEN emp1.HRLY_RATE <> emp2.HRLY_RATE THEN emp2.HRLY_RATE
    WHEN emp1.EMP_TYPE <> emp2.EMP_TYPE THEN emp2.EMP_TYPE
    WHEN emp1.TIME_TYPE <> emp2.TIME_TYPE THEN emp2.TIME_TYPE
    WHEN emp1.EXEMPT <> emp2.EXEMPT THEN emp2.EXEMPT
    ---WHEN emp1.EXPECTED_HOURS <> emp2.EXPECTED_HOURS THEN emp2.EXPECTED_HOURS
    WHEN emp1.COMP_GRADE <> emp2.COMP_GRADE THEN emp2.COMP_GRADE
    WHEN emp1.WORK_LOC_ID <> emp2.WORK_LOC_ID THEN emp2.WORK_LOC_ID
    WHEN emp1.WORK_LOC_NAME <> emp2.WORK_LOC_NAME THEN emp2.WORK_LOC_NAME
    WHEN emp1.WORK_LOC_ADD_1 <> emp2.WORK_LOC_ADD_1 THEN emp2.WORK_LOC_ADD_1
    WHEN emp1.WORK_LOC_ADD_2 <> emp2.WORK_LOC_ADD_2 THEN emp2.WORK_LOC_ADD_2
    WHEN emp1.WORK_LOC_CITY <> emp2.WORK_LOC_CITY THEN emp2.WORK_LOC_CITY
    WHEN emp1.WORK_LOC_STATE <> emp2.WORK_LOC_STATE THEN emp2.WORK_LOC_STATE
    WHEN emp1.WORK_LOC_ZIP <> emp2.WORK_LOC_ZIP THEN emp2.WORK_LOC_ZIP
    WHEN emp1.HOME_ADD_1 <> emp2.HOME_ADD_1 THEN emp2.HOME_ADD_1
    WHEN emp1.HOME_ADD_2 <> emp2.HOME_ADD_2 THEN emp2.HOME_ADD_2
    WHEN emp1.HOME_ADD_CITY <> emp2.HOME_ADD_CITY THEN emp2.HOME_ADD_CITY
    WHEN emp1.HOME_ADD_STATE <> emp2.HOME_ADD_STATE THEN emp2.HOME_ADD_STATE
    WHEN emp1.HOME_ADD_ZIP <> emp2.HOME_ADD_ZIP THEN emp2.HOME_ADD_ZIP
    WHEN emp1.HOME_ADD_ST <> emp2.HOME_ADD_ST THEN emp2.HOME_ADD_ST
    WHEN emp1.LOA <> emp2.LOA THEN emp2.LOA
    WHEN emp1.REPORTS_TO <> emp2.REPORTS_TO THEN emp2.REPORTS_TO
    WHEN emp1.REPORTS_TO_EMP_ID <> emp2.REPORTS_TO_EMP_ID THEN emp2.REPORTS_TO_EMP_ID
    WHEN emp1.REPORTS_TO_EMAIL <> emp2.REPORTS_TO_EMAIL THEN emp2.REPORTS_TO_EMAIL
    WHEN emp1.REPORTS_TO_MGR_LVL <> emp2.REPORTS_TO_MGR_LVL THEN emp2.REPORTS_TO_MGR_LVL
    ---WHEN emp1.emp_rank <> emp2.emp_rank THEN emp2.emp_rank
    ---WHEN emp1.MGR_LVL_NUM <> emp2.MGR_LVL_NUM THEN emp2.MGR_LVL_NUM
    ---WHEN emp1.HIERARCHY_TIER <> emp2.HIERARCHY_TIER THEN emp2.HIERARCHY_TIER
    WHEN emp1.TIER_1 <> emp2.TIER_1 THEN emp2.TIER_1
    WHEN emp1.TIER_2 <> emp2.TIER_2 THEN emp2.TIER_2
    WHEN emp1.TIER_3 <> emp2.TIER_3 THEN emp2.TIER_3
    WHEN emp1.TIER_4 <> emp2.TIER_4 THEN emp2.TIER_4
    WHEN emp1.TIER_5 <> emp2.TIER_5 THEN emp2.TIER_5
    WHEN emp1.TIER_6 <> emp2.TIER_6 THEN emp2.TIER_6
    ---WHEN emp1.Snapshot_FTE <> emp2.Snapshot_FTE THEN emp2.Snapshot_FTE
    ---WHEN emp1.Period_FTE <> emp2.Period_FTE THEN emp2.Period_FTE
    WHEN emp1.Info_Source <> emp2.Info_Source THEN emp2.Info_Source
    ---WHEN emp1.Calendar_period <> emp2.Calendar_period THEN emp2.Calendar_period

    ELSE NULL
    END

    from emp_main as emp1, emp_main as emp2
    where emp1.rrd = '2018-06-04' and emp2.rrd = '2018-06-01'
    and emp1.emp_id = emp2.emp_id;

    3.

    create table emp_main

    (

    RRD date,

    EMP_ID varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    JOB_REQ varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    POS_NUM varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    CANDIDATE_ID varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    EMP_STATUS varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    WORKER_TYPE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    CONT_SUP_NAME varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --POS_EMP_TYPE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --FIELD_FLAG varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    REMOTE_FLAG varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    emp_NAME varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    FIRST_NAME varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    LAST_NAME varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    RECENT_HIRE_DATE date,

    ORIG_HIRE_DATE date,

    --LOB varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    DEPT_NUM varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    DEPT_NAME varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    FUNCTIONAL_GROUP varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS, -- NEW

    PAY_TYPE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    JOB_TITLE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    JOB_CODE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    JOB_FAMILY varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    JOB_GROUP varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    JOB_FUNCTION varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS, -- NEW

    WORK_PHONE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    EMAIL varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --OFFICER varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    EMP_MGR_LVL varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    ANNUAL_RATE NUMERIC(18,4),

    HRLY_RATE NUMERIC(18,4),

    EMP_TYPE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    TIME_TYPE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    EXEMPT varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    EXPECTED_HOURS NUMERIC(18,4),

    COMP_GRADE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    WORK_LOC_ID varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    WORK_LOC_NAME varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    WORK_LOC_ADD_1 varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    WORK_LOC_ADD_2 varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    WORK_LOC_CITY varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    WORK_LOC_STATE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    WORK_LOC_ZIP varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    HOME_ADD_1 varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    HOME_ADD_2 varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    HOME_ADD_CITY varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    HOME_ADD_STATE varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    HOME_ADD_ZIP varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    HOME_ADD_ST varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --COST_CENTER_NUM varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --COST_CENTER_NAME varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --COST_CENTER_REF varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --COMPANY varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    LOA varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    REPORTS_TO varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    REPORTS_TO_EMP_ID varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    REPORTS_TO_EMAIL varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    REPORTS_TO_MGR_LVL varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    emp_rank NUMERIC(18,4),

    MGR_LVL_NUM NUMERIC(18,4),

    HIERARCHY_TIER NUMERIC(18,4),

    TIER_1 varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    TIER_2 varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    TIER_3 varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    TIER_4 varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    TIER_5 varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    TIER_6 varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --CEO varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --VP varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --Sr_Dir varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --Dir varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --Sr_Mgr varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --Mgr varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    --Supv varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    Snapshot_FTE NUMERIC(18,4),

    Period_FTE NUMERIC(18,4),

    Info_Source varchar(200) COLLATE SQL_Latin1_General_CP1_CS_AS,

    Calendar_period date

    )

    ;

    insert into emp_main

    (

    RRD,

    EMP_ID,

    POS_NUM,

    EMP_STATUS,

    WORKER_TYPE,

    CONT_SUP_NAME,

    --POS_EMP_TYPE,

    --FIELD_FLAG,

    REMOTE_FLAG,

    emp_NAME,

    FIRST_NAME,

    LAST_NAME,

    RECENT_HIRE_DATE,

    ORIG_HIRE_DATE,

    --LOB,

    DEPT_NUM,

    DEPT_NAME,

    PAY_TYPE,

    JOB_TITLE,

    JOB_CODE,

    JOB_FAMILY,

    WORK_PHONE,

    EMAIL,

    --OFFICER,

    EMP_MGR_LVL,

    ANNUAL_RATE,

    HRLY_RATE,

    EMP_TYPE,

    TIME_TYPE,

    EXEMPT,

    EXPECTED_HOURS,

    COMP_GRADE,

    WORK_LOC_ID,

    WORK_LOC_NAME,

    WORK_LOC_ADD_1,

    WORK_LOC_ADD_2,

    WORK_LOC_CITY,

    WORK_LOC_STATE,

    WORK_LOC_ZIP,

    HOME_ADD_1,

    HOME_ADD_2,

    HOME_ADD_CITY,

    HOME_ADD_STATE,

    HOME_ADD_ZIP,

    HOME_ADD_ST,

    --COST_CENTER_NUM,

    --COST_CENTER_NAME,

    --COST_CENTER_REF,

    --COMPANY,

    LOA,

    REPORTS_TO,

    REPORTS_TO_EMP_ID,

    REPORTS_TO_EMAIL,

    REPORTS_TO_MGR_LVL,

    Emp_rank,

    MGR_LVL_NUM,

    --CEO

    --VP

    --Sr_Dir

    --Dir

    --Sr_Mgr

    --Mgr

    --Supv

    Snapshot_FTE,

    Period_FTE,

    Info_Source,

    Calendar_period

    )

  • Just out of curiosity does the following work?


    DECLARE @Date1 DATE = '2018-06-04'
            , @Date2 DATE = '2018-06-01';

    WITH DateCriteria1 AS (
    SELECT
      [emp1].[RRD]
      , [emp1].[EMP_ID]
      , [emp1].[JOB_REQ]
      , [emp1].[POS_NUM]
      , [emp1].[CANDIDATE_ID]
      , [emp1].[EMP_STATUS]
      , [emp1].[WORKER_TYPE]
      , [emp1].[CONT_SUP_NAME]
      , [emp1].[REMOTE_FLAG]
      , [emp1].[emp_NAME]
      , [emp1].[FIRST_NAME]
      , [emp1].[LAST_NAME]
      , [emp1].[RECENT_HIRE_DATE]
      , [emp1].[ORIG_HIRE_DATE]
      , [emp1].[DEPT_NUM]
      , [emp1].[DEPT_NAME]
      , [emp1].[FUNCTIONAL_GROUP]
      , [emp1].[PAY_TYPE]
      , [emp1].[JOB_TITLE]
      , [emp1].[JOB_CODE]
      , [emp1].[JOB_FAMILY]
      , [emp1].[JOB_GROUP]
      , [emp1].[JOB_FUNCTION]
      , [emp1].[WORK_PHONE]
      , [emp1].
      , [emp1].[EMP_MGR_LVL]
      , [emp1].[ANNUAL_RATE]
      , [emp1].[HRLY_RATE]
      , [emp1].[EMP_TYPE]
      , [emp1].[TIME_TYPE]
      , [emp1].[EXEMPT]
      , [emp1].[EXPECTED_HOURS]
      , [emp1].[COMP_GRADE]
      , [emp1].[WORK_LOC_ID]
      , [emp1].[WORK_LOC_NAME]
      , [emp1].[WORK_LOC_ADD_1]
      , [emp1].[WORK_LOC_ADD_2]
      , [emp1].[WORK_LOC_CITY]
      , [emp1].[WORK_LOC_STATE]
      , [emp1].[WORK_LOC_ZIP]
      , [emp1].[HOME_ADD_1]
      , [emp1].[HOME_ADD_2]
      , [emp1].[HOME_ADD_CITY]
      , [emp1].[HOME_ADD_STATE]
      , [emp1].[HOME_ADD_ZIP]
      , [emp1].[HOME_ADD_ST]
      , [emp1].[LOA]
      , [emp1].[REPORTS_TO]
      , [emp1].[REPORTS_TO_EMP_ID]
      , [emp1].[REPORTS_TO_EMAIL]
      , [emp1].[REPORTS_TO_MGR_LVL]
      , [emp1].[emp_rank]
      , [emp1].[MGR_LVL_NUM]
      , [emp1].[HIERARCHY_TIER]
      , [emp1].[TIER_1]
      , [emp1].[TIER_2]
      , [emp1].[TIER_3]
      , [emp1].[TIER_4]
      , [emp1].[TIER_5]
      , [emp1].[TIER_6]
      , [emp1].[Snapshot_FTE]
      , [emp1].[Period_FTE]
      , [emp1].[Info_Source]
      , [emp1].[Calendar_period]
    FROM
      [emp_main]            AS [emp1]
    WHERE
      [emp1].[rrd]     = @Date1
    ),
    DateCriteria2 AS (
    SELECT
      [emp1].[RRD]
      , [emp1].[EMP_ID]
      , [emp1].[JOB_REQ]
      , [emp1].[POS_NUM]
      , [emp1].[CANDIDATE_ID]
      , [emp1].[EMP_STATUS]
      , [emp1].[WORKER_TYPE]
      , [emp1].[CONT_SUP_NAME]
      , [emp1].[REMOTE_FLAG]
      , [emp1].[emp_NAME]
      , [emp1].[FIRST_NAME]
      , [emp1].[LAST_NAME]
      , [emp1].[RECENT_HIRE_DATE]
      , [emp1].[ORIG_HIRE_DATE]
      , [emp1].[DEPT_NUM]
      , [emp1].[DEPT_NAME]
      , [emp1].[FUNCTIONAL_GROUP]
      , [emp1].[PAY_TYPE]
      , [emp1].[JOB_TITLE]
      , [emp1].[JOB_CODE]
      , [emp1].[JOB_FAMILY]
      , [emp1].[JOB_GROUP]
      , [emp1].[JOB_FUNCTION]
      , [emp1].[WORK_PHONE]
      , [emp1].
      , [emp1].[EMP_MGR_LVL]
      , [emp1].[ANNUAL_RATE]
      , [emp1].[HRLY_RATE]
      , [emp1].[EMP_TYPE]
      , [emp1].[TIME_TYPE]
      , [emp1].[EXEMPT]
      , [emp1].[EXPECTED_HOURS]
      , [emp1].[COMP_GRADE]
      , [emp1].[WORK_LOC_ID]
      , [emp1].[WORK_LOC_NAME]
      , [emp1].[WORK_LOC_ADD_1]
      , [emp1].[WORK_LOC_ADD_2]
      , [emp1].[WORK_LOC_CITY]
      , [emp1].[WORK_LOC_STATE]
      , [emp1].[WORK_LOC_ZIP]
      , [emp1].[HOME_ADD_1]
      , [emp1].[HOME_ADD_2]
      , [emp1].[HOME_ADD_CITY]
      , [emp1].[HOME_ADD_STATE]
      , [emp1].[HOME_ADD_ZIP]
      , [emp1].[HOME_ADD_ST]
      , [emp1].[LOA]
      , [emp1].[REPORTS_TO]
      , [emp1].[REPORTS_TO_EMP_ID]
      , [emp1].[REPORTS_TO_EMAIL]
      , [emp1].[REPORTS_TO_MGR_LVL]
      , [emp1].[emp_rank]
      , [emp1].[MGR_LVL_NUM]
      , [emp1].[HIERARCHY_TIER]
      , [emp1].[TIER_1]
      , [emp1].[TIER_2]
      , [emp1].[TIER_3]
      , [emp1].[TIER_4]
      , [emp1].[TIER_5]
      , [emp1].[TIER_6]
      , [emp1].[Snapshot_FTE]
      , [emp1].[Period_FTE]
      , [emp1].[Info_Source]
      , [emp1].[Calendar_period]
    FROM
      [emp_main]            AS [emp1]
    WHERE
      [emp1].[rrd]     = @Date2
    ),
    Diff1to2 AS (
    SELECT
      [emp1].[EMP_ID]
      , [emp1].[JOB_REQ]
      , [emp1].[POS_NUM]
      , [emp1].[CANDIDATE_ID]
      , [emp1].[EMP_STATUS]
      , [emp1].[WORKER_TYPE]
      , [emp1].[CONT_SUP_NAME]
      , [emp1].[REMOTE_FLAG]
      , [emp1].[emp_NAME]
      , [emp1].[FIRST_NAME]
      , [emp1].[LAST_NAME]
      , [emp1].[RECENT_HIRE_DATE]
      , [emp1].[ORIG_HIRE_DATE]
      , [emp1].[DEPT_NUM]
      , [emp1].[DEPT_NAME]
      , [emp1].[FUNCTIONAL_GROUP]
      , [emp1].[PAY_TYPE]
      , [emp1].[JOB_TITLE]
      , [emp1].[JOB_CODE]
      , [emp1].[JOB_FAMILY]
      , [emp1].[JOB_GROUP]
      , [emp1].[JOB_FUNCTION]
      , [emp1].[WORK_PHONE]
      , [emp1].
      , [emp1].[EMP_MGR_LVL]
      , [emp1].[ANNUAL_RATE]
      , [emp1].[HRLY_RATE]
      , [emp1].[EMP_TYPE]
      , [emp1].[TIME_TYPE]
      , [emp1].[EXEMPT]
      , [emp1].[EXPECTED_HOURS]
      , [emp1].[COMP_GRADE]
      , [emp1].[WORK_LOC_ID]
      , [emp1].[WORK_LOC_NAME]
      , [emp1].[WORK_LOC_ADD_1]
      , [emp1].[WORK_LOC_ADD_2]
      , [emp1].[WORK_LOC_CITY]
      , [emp1].[WORK_LOC_STATE]
      , [emp1].[WORK_LOC_ZIP]
      , [emp1].[HOME_ADD_1]
      , [emp1].[HOME_ADD_2]
      , [emp1].[HOME_ADD_CITY]
      , [emp1].[HOME_ADD_STATE]
      , [emp1].[HOME_ADD_ZIP]
      , [emp1].[HOME_ADD_ST]
      , [emp1].[LOA]
      , [emp1].[REPORTS_TO]
      , [emp1].[REPORTS_TO_EMP_ID]
      , [emp1].[REPORTS_TO_EMAIL]
      , [emp1].[REPORTS_TO_MGR_LVL]
      , [emp1].[emp_rank]
      , [emp1].[MGR_LVL_NUM]
      , [emp1].[HIERARCHY_TIER]
      , [emp1].[TIER_1]
      , [emp1].[TIER_2]
      , [emp1].[TIER_3]
      , [emp1].[TIER_4]
      , [emp1].[TIER_5]
      , [emp1].[TIER_6]
      , [emp1].[Snapshot_FTE]
      , [emp1].[Period_FTE]
      , [emp1].[Info_Source]
      , [emp1].[Calendar_period]
    FROM
      [DateCriteria1] AS [emp1]
    EXCEPT
    SELECT
      [emp2].[EMP_ID]
      , [emp2].[JOB_REQ]
      , [emp2].[POS_NUM]
      , [emp2].[CANDIDATE_ID]
      , [emp2].[EMP_STATUS]
      , [emp2].[WORKER_TYPE]
      , [emp2].[CONT_SUP_NAME]
      , [emp2].[REMOTE_FLAG]
      , [emp2].[emp_NAME]
      , [emp2].[FIRST_NAME]
      , [emp2].[LAST_NAME]
      , [emp2].[RECENT_HIRE_DATE]
      , [emp2].[ORIG_HIRE_DATE]
      , [emp2].[DEPT_NUM]
      , [emp2].[DEPT_NAME]
      , [emp2].[FUNCTIONAL_GROUP]
      , [emp2].[PAY_TYPE]
      , [emp2].[JOB_TITLE]
      , [emp2].[JOB_CODE]
      , [emp2].[JOB_FAMILY]
      , [emp2].[JOB_GROUP]
      , [emp2].[JOB_FUNCTION]
      , [emp2].[WORK_PHONE]
      , [emp2].
      , [emp2].[EMP_MGR_LVL]
      , [emp2].[ANNUAL_RATE]
      , [emp2].[HRLY_RATE]
      , [emp2].[EMP_TYPE]
      , [emp2].[TIME_TYPE]
      , [emp2].[EXEMPT]
      , [emp2].[EXPECTED_HOURS]
      , [emp2].[COMP_GRADE]
      , [emp2].[WORK_LOC_ID]
      , [emp2].[WORK_LOC_NAME]
      , [emp2].[WORK_LOC_ADD_1]
      , [emp2].[WORK_LOC_ADD_2]
      , [emp2].[WORK_LOC_CITY]
      , [emp2].[WORK_LOC_STATE]
      , [emp2].[WORK_LOC_ZIP]
      , [emp2].[HOME_ADD_1]
      , [emp2].[HOME_ADD_2]
      , [emp2].[HOME_ADD_CITY]
      , [emp2].[HOME_ADD_STATE]
      , [emp2].[HOME_ADD_ZIP]
      , [emp2].[HOME_ADD_ST]
      , [emp2].[LOA]
      , [emp2].[REPORTS_TO]
      , [emp2].[REPORTS_TO_EMP_ID]
      , [emp2].[REPORTS_TO_EMAIL]
      , [emp2].[REPORTS_TO_MGR_LVL]
      , [emp2].[emp_rank]
      , [emp2].[MGR_LVL_NUM]
      , [emp2].[HIERARCHY_TIER]
      , [emp2].[TIER_1]
      , [emp2].[TIER_2]
      , [emp2].[TIER_3]
      , [emp2].[TIER_4]
      , [emp2].[TIER_5]
      , [emp2].[TIER_6]
      , [emp2].[Snapshot_FTE]
      , [emp2].[Period_FTE]
      , [emp2].[Info_Source]
      , [emp2].[Calendar_period]
    FROM
      [DateCriteria2] AS [emp2]
    ),
    Diff2to1 AS (
    SELECT
      [emp2].[EMP_ID]
      , [emp2].[JOB_REQ]
      , [emp2].[POS_NUM]
      , [emp2].[CANDIDATE_ID]
      , [emp2].[EMP_STATUS]
      , [emp2].[WORKER_TYPE]
      , [emp2].[CONT_SUP_NAME]
      , [emp2].[REMOTE_FLAG]
      , [emp2].[emp_NAME]
      , [emp2].[FIRST_NAME]
      , [emp2].[LAST_NAME]
      , [emp2].[RECENT_HIRE_DATE]
      , [emp2].[ORIG_HIRE_DATE]
      , [emp2].[DEPT_NUM]
      , [emp2].[DEPT_NAME]
      , [emp2].[FUNCTIONAL_GROUP]
      , [emp2].[PAY_TYPE]
      , [emp2].[JOB_TITLE]
      , [emp2].[JOB_CODE]
      , [emp2].[JOB_FAMILY]
      , [emp2].[JOB_GROUP]
      , [emp2].[JOB_FUNCTION]
      , [emp2].[WORK_PHONE]
      , [emp2].
      , [emp2].[EMP_MGR_LVL]
      , [emp2].[ANNUAL_RATE]
      , [emp2].[HRLY_RATE]
      , [emp2].[EMP_TYPE]
      , [emp2].[TIME_TYPE]
      , [emp2].[EXEMPT]
      , [emp2].[EXPECTED_HOURS]
      , [emp2].[COMP_GRADE]
      , [emp2].[WORK_LOC_ID]
      , [emp2].[WORK_LOC_NAME]
      , [emp2].[WORK_LOC_ADD_1]
      , [emp2].[WORK_LOC_ADD_2]
      , [emp2].[WORK_LOC_CITY]
      , [emp2].[WORK_LOC_STATE]
      , [emp2].[WORK_LOC_ZIP]
      , [emp2].[HOME_ADD_1]
      , [emp2].[HOME_ADD_2]
      , [emp2].[HOME_ADD_CITY]
      , [emp2].[HOME_ADD_STATE]
      , [emp2].[HOME_ADD_ZIP]
      , [emp2].[HOME_ADD_ST]
      , [emp2].[LOA]
      , [emp2].[REPORTS_TO]
      , [emp2].[REPORTS_TO_EMP_ID]
      , [emp2].[REPORTS_TO_EMAIL]
      , [emp2].[REPORTS_TO_MGR_LVL]
      , [emp2].[emp_rank]
      , [emp2].[MGR_LVL_NUM]
      , [emp2].[HIERARCHY_TIER]
      , [emp2].[TIER_1]
      , [emp2].[TIER_2]
      , [emp2].[TIER_3]
      , [emp2].[TIER_4]
      , [emp2].[TIER_5]
      , [emp2].[TIER_6]
      , [emp2].[Snapshot_FTE]
      , [emp2].[Period_FTE]
      , [emp2].[Info_Source]
      , [emp2].[Calendar_period]
    FROM
      [DateCriteria2] AS [emp2]
    EXCEPT
    SELECT
      [emp1].[EMP_ID]
      , [emp1].[JOB_REQ]
      , [emp1].[POS_NUM]
      , [emp1].[CANDIDATE_ID]
      , [emp1].[EMP_STATUS]
      , [emp1].[WORKER_TYPE]
      , [emp1].[CONT_SUP_NAME]
      , [emp1].[REMOTE_FLAG]
      , [emp1].[emp_NAME]
      , [emp1].[FIRST_NAME]
      , [emp1].[LAST_NAME]
      , [emp1].[RECENT_HIRE_DATE]
      , [emp1].[ORIG_HIRE_DATE]
      , [emp1].[DEPT_NUM]
      , [emp1].[DEPT_NAME]
      , [emp1].[FUNCTIONAL_GROUP]
      , [emp1].[PAY_TYPE]
      , [emp1].[JOB_TITLE]
      , [emp1].[JOB_CODE]
      , [emp1].[JOB_FAMILY]
      , [emp1].[JOB_GROUP]
      , [emp1].[JOB_FUNCTION]
      , [emp1].[WORK_PHONE]
      , [emp1].
      , [emp1].[EMP_MGR_LVL]
      , [emp1].[ANNUAL_RATE]
      , [emp1].[HRLY_RATE]
      , [emp1].[EMP_TYPE]
      , [emp1].[TIME_TYPE]
      , [emp1].[EXEMPT]
      , [emp1].[EXPECTED_HOURS]
      , [emp1].[COMP_GRADE]
      , [emp1].[WORK_LOC_ID]
      , [emp1].[WORK_LOC_NAME]
      , [emp1].[WORK_LOC_ADD_1]
      , [emp1].[WORK_LOC_ADD_2]
      , [emp1].[WORK_LOC_CITY]
      , [emp1].[WORK_LOC_STATE]
      , [emp1].[WORK_LOC_ZIP]
      , [emp1].[HOME_ADD_1]
      , [emp1].[HOME_ADD_2]
      , [emp1].[HOME_ADD_CITY]
      , [emp1].[HOME_ADD_STATE]
      , [emp1].[HOME_ADD_ZIP]
      , [emp1].[HOME_ADD_ST]
      , [emp1].[LOA]
      , [emp1].[REPORTS_TO]
      , [emp1].[REPORTS_TO_EMP_ID]
      , [emp1].[REPORTS_TO_EMAIL]
      , [emp1].[REPORTS_TO_MGR_LVL]
      , [emp1].[emp_rank]
      , [emp1].[MGR_LVL_NUM]
      , [emp1].[HIERARCHY_TIER]
      , [emp1].[TIER_1]
      , [emp1].[TIER_2]
      , [emp1].[TIER_3]
      , [emp1].[TIER_4]
      , [emp1].[TIER_5]
      , [emp1].[TIER_6]
      , [emp1].[Snapshot_FTE]
      , [emp1].[Period_FTE]
      , [emp1].[Info_Source]
      , [emp1].[Calendar_period]
    FROM
      [DateCriteria1] AS [emp1]
    )
    SELECT
      @Date1 AS RRD
      , [emp1].[EMP_ID]
      , [emp1].[JOB_REQ]
      , [emp1].[POS_NUM]
      , [emp1].[CANDIDATE_ID]
      , [emp1].[EMP_STATUS]
      , [emp1].[WORKER_TYPE]
      , [emp1].[CONT_SUP_NAME]
      , [emp1].[REMOTE_FLAG]
      , [emp1].[emp_NAME]
      , [emp1].[FIRST_NAME]
      , [emp1].[LAST_NAME]
      , [emp1].[RECENT_HIRE_DATE]
      , [emp1].[ORIG_HIRE_DATE]
      , [emp1].[DEPT_NUM]
      , [emp1].[DEPT_NAME]
      , [emp1].[FUNCTIONAL_GROUP]
      , [emp1].[PAY_TYPE]
      , [emp1].[JOB_TITLE]
      , [emp1].[JOB_CODE]
      , [emp1].[JOB_FAMILY]
      , [emp1].[JOB_GROUP]
      , [emp1].[JOB_FUNCTION]
      , [emp1].[WORK_PHONE]
      , [emp1].
      , [emp1].[EMP_MGR_LVL]
      , [emp1].[ANNUAL_RATE]
      , [emp1].[HRLY_RATE]
      , [emp1].[EMP_TYPE]
      , [emp1].[TIME_TYPE]
      , [emp1].[EXEMPT]
      , [emp1].[EXPECTED_HOURS]
      , [emp1].[COMP_GRADE]
      , [emp1].[WORK_LOC_ID]
      , [emp1].[WORK_LOC_NAME]
      , [emp1].[WORK_LOC_ADD_1]
      , [emp1].[WORK_LOC_ADD_2]
      , [emp1].[WORK_LOC_CITY]
      , [emp1].[WORK_LOC_STATE]
      , [emp1].[WORK_LOC_ZIP]
      , [emp1].[HOME_ADD_1]
      , [emp1].[HOME_ADD_2]
      , [emp1].[HOME_ADD_CITY]
      , [emp1].[HOME_ADD_STATE]
      , [emp1].[HOME_ADD_ZIP]
      , [emp1].[HOME_ADD_ST]
      , [emp1].[LOA]
      , [emp1].[REPORTS_TO]
      , [emp1].[REPORTS_TO_EMP_ID]
      , [emp1].[REPORTS_TO_EMAIL]
      , [emp1].[REPORTS_TO_MGR_LVL]
      , [emp1].[emp_rank]
      , [emp1].[MGR_LVL_NUM]
      , [emp1].[HIERARCHY_TIER]
      , [emp1].[TIER_1]
      , [emp1].[TIER_2]
      , [emp1].[TIER_3]
      , [emp1].[TIER_4]
      , [emp1].[TIER_5]
      , [emp1].[TIER_6]
      , [emp1].[Snapshot_FTE]
      , [emp1].[Period_FTE]
      , [emp1].[Info_Source]
      , [emp1].[Calendar_period]
    FROM
      [Diff1to2] AS [emp1]
    UNION
    SELECT
      @Date2 AS RRD
      , [emp2].[EMP_ID]
      , [emp2].[JOB_REQ]
      , [emp2].[POS_NUM]
      , [emp2].[CANDIDATE_ID]
      , [emp2].[EMP_STATUS]
      , [emp2].[WORKER_TYPE]
      , [emp2].[CONT_SUP_NAME]
      , [emp2].[REMOTE_FLAG]
      , [emp2].[emp_NAME]
      , [emp2].[FIRST_NAME]
      , [emp2].[LAST_NAME]
      , [emp2].[RECENT_HIRE_DATE]
      , [emp2].[ORIG_HIRE_DATE]
      , [emp2].[DEPT_NUM]
      , [emp2].[DEPT_NAME]
      , [emp2].[FUNCTIONAL_GROUP]
      , [emp2].[PAY_TYPE]
      , [emp2].[JOB_TITLE]
      , [emp2].[JOB_CODE]
      , [emp2].[JOB_FAMILY]
      , [emp2].[JOB_GROUP]
      , [emp2].[JOB_FUNCTION]
      , [emp2].[WORK_PHONE]
      , [emp2].
      , [emp2].[EMP_MGR_LVL]
      , [emp2].[ANNUAL_RATE]
      , [emp2].[HRLY_RATE]
      , [emp2].[EMP_TYPE]
      , [emp2].[TIME_TYPE]
      , [emp2].[EXEMPT]
      , [emp2].[EXPECTED_HOURS]
      , [emp2].[COMP_GRADE]
      , [emp2].[WORK_LOC_ID]
      , [emp2].[WORK_LOC_NAME]
      , [emp2].[WORK_LOC_ADD_1]
      , [emp2].[WORK_LOC_ADD_2]
      , [emp2].[WORK_LOC_CITY]
      , [emp2].[WORK_LOC_STATE]
      , [emp2].[WORK_LOC_ZIP]
      , [emp2].[HOME_ADD_1]
      , [emp2].[HOME_ADD_2]
      , [emp2].[HOME_ADD_CITY]
      , [emp2].[HOME_ADD_STATE]
      , [emp2].[HOME_ADD_ZIP]
      , [emp2].[HOME_ADD_ST]
      , [emp2].[LOA]
      , [emp2].[REPORTS_TO]
      , [emp2].[REPORTS_TO_EMP_ID]
      , [emp2].[REPORTS_TO_EMAIL]
      , [emp2].[REPORTS_TO_MGR_LVL]
      , [emp2].[emp_rank]
      , [emp2].[MGR_LVL_NUM]
      , [emp2].[HIERARCHY_TIER]
      , [emp2].[TIER_1]
      , [emp2].[TIER_2]
      , [emp2].[TIER_3]
      , [emp2].[TIER_4]
      , [emp2].[TIER_5]
      , [emp2].[TIER_6]
      , [emp2].[Snapshot_FTE]
      , [emp2].[Period_FTE]
      , [emp2].[Info_Source]
      , [emp2].[Calendar_period]
    FROM
      [Diff2to1] AS [emp2];
    GO
     

  • Well... re-formatting your code to improve it does mean that you still need to have it inside of the code="SQL" and /code tags, so the last post didn't help any on that front.
    Also, you didn't provide any actual data for your INSERT statement.   Finally, let's talk about your objective.   You show some sample output, but it shows identical column
    names for both halves of the comparison, and you would be better served by having those actually be different.   Given that sample data, is there perhaps some over-arching
    need in terms of identifying what has changed?  Do you really need to know exactly what has changed?   That question naturally leads to wanting to know WHEN the change
    took place, which then leads to a host of other possible questions.   As your original query would only have identified the first of the columns in the CASE statement that had
    changed, I'm not at all sure that had it worked, that it would have been useful.   Thus I'm wondering what the ultimate objective is, as maybe there's another way to go about
    it that doesn't involve comparing every single column.   Mind you, that still might be okay, but you would probably be best served in that case by creating an output column
    for each comparison, and thus, rather than one giant CASE statement, you would have one for each source column that shows the result of the comparison.

    Steve (aka sgmunson) 🙂 🙂 🙂
    Rent Servers for Income (picks and shovels strategy)

  • Lynn Pettis - Tuesday, June 19, 2018 10:24 AM

    Just out of curiosity does the following work?


    DECLARE @Date1 DATE = '2018-06-04'
            , @Date2 DATE = '2018-06-01';

    WITH DateCriteria1 AS (
    SELECT
      [emp1].[RRD]
      , [emp1].[EMP_ID]
      , [emp1].[JOB_REQ]
      , [emp1].[POS_NUM]
      , [emp1].[CANDIDATE_ID]
      , [emp1].[EMP_STATUS]
      , [emp1].[WORKER_TYPE]
      , [emp1].[CONT_SUP_NAME]
      , [emp1].[REMOTE_FLAG]
      , [emp1].[emp_NAME]
      , [emp1].[FIRST_NAME]
      , [emp1].[LAST_NAME]
      , [emp1].[RECENT_HIRE_DATE]
      , [emp1].[ORIG_HIRE_DATE]
      , [emp1].[DEPT_NUM]
      , [emp1].[DEPT_NAME]
      , [emp1].[FUNCTIONAL_GROUP]
      , [emp1].[PAY_TYPE]
      , [emp1].[JOB_TITLE]
      , [emp1].[JOB_CODE]
      , [emp1].[JOB_FAMILY]
      , [emp1].[JOB_GROUP]
      , [emp1].[JOB_FUNCTION]
      , [emp1].[WORK_PHONE]
      , [emp1].
      , [emp1].[EMP_MGR_LVL]
      , [emp1].[ANNUAL_RATE]
      , [emp1].[HRLY_RATE]
      , [emp1].[EMP_TYPE]
      , [emp1].[TIME_TYPE]
      , [emp1].[EXEMPT]
      , [emp1].[EXPECTED_HOURS]
      , [emp1].[COMP_GRADE]
      , [emp1].[WORK_LOC_ID]
      , [emp1].[WORK_LOC_NAME]
      , [emp1].[WORK_LOC_ADD_1]
      , [emp1].[WORK_LOC_ADD_2]
      , [emp1].[WORK_LOC_CITY]
      , [emp1].[WORK_LOC_STATE]
      , [emp1].[WORK_LOC_ZIP]
      , [emp1].[HOME_ADD_1]
      , [emp1].[HOME_ADD_2]
      , [emp1].[HOME_ADD_CITY]
      , [emp1].[HOME_ADD_STATE]
      , [emp1].[HOME_ADD_ZIP]
      , [emp1].[HOME_ADD_ST]
      , [emp1].[LOA]
      , [emp1].[REPORTS_TO]
      , [emp1].[REPORTS_TO_EMP_ID]
      , [emp1].[REPORTS_TO_EMAIL]
      , [emp1].[REPORTS_TO_MGR_LVL]
      , [emp1].[emp_rank]
      , [emp1].[MGR_LVL_NUM]
      , [emp1].[HIERARCHY_TIER]
      , [emp1].[TIER_1]
      , [emp1].[TIER_2]
      , [emp1].[TIER_3]
      , [emp1].[TIER_4]
      , [emp1].[TIER_5]
      , [emp1].[TIER_6]
      , [emp1].[Snapshot_FTE]
      , [emp1].[Period_FTE]
      , [emp1].[Info_Source]
      , [emp1].[Calendar_period]
    FROM
      [emp_main]            AS [emp1]
    WHERE
      [emp1].[rrd]     = @Date1
    ),
    DateCriteria2 AS (
    SELECT
      [emp1].[RRD]
      , [emp1].[EMP_ID]
      , [emp1].[JOB_REQ]
      , [emp1].[POS_NUM]
      , [emp1].[CANDIDATE_ID]
      , [emp1].[EMP_STATUS]
      , [emp1].[WORKER_TYPE]
      , [emp1].[CONT_SUP_NAME]
      , [emp1].[REMOTE_FLAG]
      , [emp1].[emp_NAME]
      , [emp1].[FIRST_NAME]
      , [emp1].[LAST_NAME]
      , [emp1].[RECENT_HIRE_DATE]
      , [emp1].[ORIG_HIRE_DATE]
      , [emp1].[DEPT_NUM]
      , [emp1].[DEPT_NAME]
      , [emp1].[FUNCTIONAL_GROUP]
      , [emp1].[PAY_TYPE]
      , [emp1].[JOB_TITLE]
      , [emp1].[JOB_CODE]
      , [emp1].[JOB_FAMILY]
      , [emp1].[JOB_GROUP]
      , [emp1].[JOB_FUNCTION]
      , [emp1].[WORK_PHONE]
      , [emp1].
      , [emp1].[EMP_MGR_LVL]
      , [emp1].[ANNUAL_RATE]
      , [emp1].[HRLY_RATE]
      , [emp1].[EMP_TYPE]
      , [emp1].[TIME_TYPE]
      , [emp1].[EXEMPT]
      , [emp1].[EXPECTED_HOURS]
      , [emp1].[COMP_GRADE]
      , [emp1].[WORK_LOC_ID]
      , [emp1].[WORK_LOC_NAME]
      , [emp1].[WORK_LOC_ADD_1]
      , [emp1].[WORK_LOC_ADD_2]
      , [emp1].[WORK_LOC_CITY]
      , [emp1].[WORK_LOC_STATE]
      , [emp1].[WORK_LOC_ZIP]
      , [emp1].[HOME_ADD_1]
      , [emp1].[HOME_ADD_2]
      , [emp1].[HOME_ADD_CITY]
      , [emp1].[HOME_ADD_STATE]
      , [emp1].[HOME_ADD_ZIP]
      , [emp1].[HOME_ADD_ST]
      , [emp1].[LOA]
      , [emp1].[REPORTS_TO]
      , [emp1].[REPORTS_TO_EMP_ID]
      , [emp1].[REPORTS_TO_EMAIL]
      , [emp1].[REPORTS_TO_MGR_LVL]
      , [emp1].[emp_rank]
      , [emp1].[MGR_LVL_NUM]
      , [emp1].[HIERARCHY_TIER]
      , [emp1].[TIER_1]
      , [emp1].[TIER_2]
      , [emp1].[TIER_3]
      , [emp1].[TIER_4]
      , [emp1].[TIER_5]
      , [emp1].[TIER_6]
      , [emp1].[Snapshot_FTE]
      , [emp1].[Period_FTE]
      , [emp1].[Info_Source]
      , [emp1].[Calendar_period]
    FROM
      [emp_main]            AS [emp1]
    WHERE
      [emp1].[rrd]     = @Date2
    ),
    Diff1to2 AS (
    SELECT
      [emp1].[EMP_ID]
      , [emp1].[JOB_REQ]
      , [emp1].[POS_NUM]
      , [emp1].[CANDIDATE_ID]
      , [emp1].[EMP_STATUS]
      , [emp1].[WORKER_TYPE]
      , [emp1].[CONT_SUP_NAME]
      , [emp1].[REMOTE_FLAG]
      , [emp1].[emp_NAME]
      , [emp1].[FIRST_NAME]
      , [emp1].[LAST_NAME]
      , [emp1].[RECENT_HIRE_DATE]
      , [emp1].[ORIG_HIRE_DATE]
      , [emp1].[DEPT_NUM]
      , [emp1].[DEPT_NAME]
      , [emp1].[FUNCTIONAL_GROUP]
      , [emp1].[PAY_TYPE]
      , [emp1].[JOB_TITLE]
      , [emp1].[JOB_CODE]
      , [emp1].[JOB_FAMILY]
      , [emp1].[JOB_GROUP]
      , [emp1].[JOB_FUNCTION]
      , [emp1].[WORK_PHONE]
      , [emp1].
      , [emp1].[EMP_MGR_LVL]
      , [emp1].[ANNUAL_RATE]
      , [emp1].[HRLY_RATE]
      , [emp1].[EMP_TYPE]
      , [emp1].[TIME_TYPE]
      , [emp1].[EXEMPT]
      , [emp1].[EXPECTED_HOURS]
      , [emp1].[COMP_GRADE]
      , [emp1].[WORK_LOC_ID]
      , [emp1].[WORK_LOC_NAME]
      , [emp1].[WORK_LOC_ADD_1]
      , [emp1].[WORK_LOC_ADD_2]
      , [emp1].[WORK_LOC_CITY]
      , [emp1].[WORK_LOC_STATE]
      , [emp1].[WORK_LOC_ZIP]
      , [emp1].[HOME_ADD_1]
      , [emp1].[HOME_ADD_2]
      , [emp1].[HOME_ADD_CITY]
      , [emp1].[HOME_ADD_STATE]
      , [emp1].[HOME_ADD_ZIP]
      , [emp1].[HOME_ADD_ST]
      , [emp1].[LOA]
      , [emp1].[REPORTS_TO]
      , [emp1].[REPORTS_TO_EMP_ID]
      , [emp1].[REPORTS_TO_EMAIL]
      , [emp1].[REPORTS_TO_MGR_LVL]
      , [emp1].[emp_rank]
      , [emp1].[MGR_LVL_NUM]
      , [emp1].[HIERARCHY_TIER]
      , [emp1].[TIER_1]
      , [emp1].[TIER_2]
      , [emp1].[TIER_3]
      , [emp1].[TIER_4]
      , [emp1].[TIER_5]
      , [emp1].[TIER_6]
      , [emp1].[Snapshot_FTE]
      , [emp1].[Period_FTE]
      , [emp1].[Info_Source]
      , [emp1].[Calendar_period]
    FROM
      [DateCriteria1] AS [emp1]
    EXCEPT
    SELECT
      [emp2].[EMP_ID]
      , [emp2].[JOB_REQ]
      , [emp2].[POS_NUM]
      , [emp2].[CANDIDATE_ID]
      , [emp2].[EMP_STATUS]
      , [emp2].[WORKER_TYPE]
      , [emp2].[CONT_SUP_NAME]
      , [emp2].[REMOTE_FLAG]
      , [emp2].[emp_NAME]
      , [emp2].[FIRST_NAME]
      , [emp2].[LAST_NAME]
      , [emp2].[RECENT_HIRE_DATE]
      , [emp2].[ORIG_HIRE_DATE]
      , [emp2].[DEPT_NUM]
      , [emp2].[DEPT_NAME]
      , [emp2].[FUNCTIONAL_GROUP]
      , [emp2].[PAY_TYPE]
      , [emp2].[JOB_TITLE]
      , [emp2].[JOB_CODE]
      , [emp2].[JOB_FAMILY]
      , [emp2].[JOB_GROUP]
      , [emp2].[JOB_FUNCTION]
      , [emp2].[WORK_PHONE]
      , [emp2].
      , [emp2].[EMP_MGR_LVL]
      , [emp2].[ANNUAL_RATE]
      , [emp2].[HRLY_RATE]
      , [emp2].[EMP_TYPE]
      , [emp2].[TIME_TYPE]
      , [emp2].[EXEMPT]
      , [emp2].[EXPECTED_HOURS]
      , [emp2].[COMP_GRADE]
      , [emp2].[WORK_LOC_ID]
      , [emp2].[WORK_LOC_NAME]
      , [emp2].[WORK_LOC_ADD_1]
      , [emp2].[WORK_LOC_ADD_2]
      , [emp2].[WORK_LOC_CITY]
      , [emp2].[WORK_LOC_STATE]
      , [emp2].[WORK_LOC_ZIP]
      , [emp2].[HOME_ADD_1]
      , [emp2].[HOME_ADD_2]
      , [emp2].[HOME_ADD_CITY]
      , [emp2].[HOME_ADD_STATE]
      , [emp2].[HOME_ADD_ZIP]
      , [emp2].[HOME_ADD_ST]
      , [emp2].[LOA]
      , [emp2].[REPORTS_TO]
      , [emp2].[REPORTS_TO_EMP_ID]
      , [emp2].[REPORTS_TO_EMAIL]
      , [emp2].[REPORTS_TO_MGR_LVL]
      , [emp2].[emp_rank]
      , [emp2].[MGR_LVL_NUM]
      , [emp2].[HIERARCHY_TIER]
      , [emp2].[TIER_1]
      , [emp2].[TIER_2]
      , [emp2].[TIER_3]
      , [emp2].[TIER_4]
      , [emp2].[TIER_5]
      , [emp2].[TIER_6]
      , [emp2].[Snapshot_FTE]
      , [emp2].[Period_FTE]
      , [emp2].[Info_Source]
      , [emp2].[Calendar_period]
    FROM
      [DateCriteria2] AS [emp2]
    ),
    Diff2to1 AS (
    SELECT
      [emp2].[EMP_ID]
      , [emp2].[JOB_REQ]
      , [emp2].[POS_NUM]
      , [emp2].[CANDIDATE_ID]
      , [emp2].[EMP_STATUS]
      , [emp2].[WORKER_TYPE]
      , [emp2].[CONT_SUP_NAME]
      , [emp2].[REMOTE_FLAG]
      , [emp2].[emp_NAME]
      , [emp2].[FIRST_NAME]
      , [emp2].[LAST_NAME]
      , [emp2].[RECENT_HIRE_DATE]
      , [emp2].[ORIG_HIRE_DATE]
      , [emp2].[DEPT_NUM]
      , [emp2].[DEPT_NAME]
      , [emp2].[FUNCTIONAL_GROUP]
      , [emp2].[PAY_TYPE]
      , [emp2].[JOB_TITLE]
      , [emp2].[JOB_CODE]
      , [emp2].[JOB_FAMILY]
      , [emp2].[JOB_GROUP]
      , [emp2].[JOB_FUNCTION]
      , [emp2].[WORK_PHONE]
      , [emp2].
      , [emp2].[EMP_MGR_LVL]
      , [emp2].[ANNUAL_RATE]
      , [emp2].[HRLY_RATE]
      , [emp2].[EMP_TYPE]
      , [emp2].[TIME_TYPE]
      , [emp2].[EXEMPT]
      , [emp2].[EXPECTED_HOURS]
      , [emp2].[COMP_GRADE]
      , [emp2].[WORK_LOC_ID]
      , [emp2].[WORK_LOC_NAME]
      , [emp2].[WORK_LOC_ADD_1]
      , [emp2].[WORK_LOC_ADD_2]
      , [emp2].[WORK_LOC_CITY]
      , [emp2].[WORK_LOC_STATE]
      , [emp2].[WORK_LOC_ZIP]
      , [emp2].[HOME_ADD_1]
      , [emp2].[HOME_ADD_2]
      , [emp2].[HOME_ADD_CITY]
      , [emp2].[HOME_ADD_STATE]
      , [emp2].[HOME_ADD_ZIP]
      , [emp2].[HOME_ADD_ST]
      , [emp2].[LOA]
      , [emp2].[REPORTS_TO]
      , [emp2].[REPORTS_TO_EMP_ID]
      , [emp2].[REPORTS_TO_EMAIL]
      , [emp2].[REPORTS_TO_MGR_LVL]
      , [emp2].[emp_rank]
      , [emp2].[MGR_LVL_NUM]
      , [emp2].[HIERARCHY_TIER]
      , [emp2].[TIER_1]
      , [emp2].[TIER_2]
      , [emp2].[TIER_3]
      , [emp2].[TIER_4]
      , [emp2].[TIER_5]
      , [emp2].[TIER_6]
      , [emp2].[Snapshot_FTE]
      , [emp2].[Period_FTE]
      , [emp2].[Info_Source]
      , [emp2].[Calendar_period]
    FROM
      [DateCriteria2] AS [emp2]
    EXCEPT
    SELECT
      [emp1].[EMP_ID]
      , [emp1].[JOB_REQ]
      , [emp1].[POS_NUM]
      , [emp1].[CANDIDATE_ID]
      , [emp1].[EMP_STATUS]
      , [emp1].[WORKER_TYPE]
      , [emp1].[CONT_SUP_NAME]
      , [emp1].[REMOTE_FLAG]
      , [emp1].[emp_NAME]
      , [emp1].[FIRST_NAME]
      , [emp1].[LAST_NAME]
      , [emp1].[RECENT_HIRE_DATE]
      , [emp1].[ORIG_HIRE_DATE]
      , [emp1].[DEPT_NUM]
      , [emp1].[DEPT_NAME]
      , [emp1].[FUNCTIONAL_GROUP]
      , [emp1].[PAY_TYPE]
      , [emp1].[JOB_TITLE]
      , [emp1].[JOB_CODE]
      , [emp1].[JOB_FAMILY]
      , [emp1].[JOB_GROUP]
      , [emp1].[JOB_FUNCTION]
      , [emp1].[WORK_PHONE]
      , [emp1].
      , [emp1].[EMP_MGR_LVL]
      , [emp1].[ANNUAL_RATE]
      , [emp1].[HRLY_RATE]
      , [emp1].[EMP_TYPE]
      , [emp1].[TIME_TYPE]
      , [emp1].[EXEMPT]
      , [emp1].[EXPECTED_HOURS]
      , [emp1].[COMP_GRADE]
      , [emp1].[WORK_LOC_ID]
      , [emp1].[WORK_LOC_NAME]
      , [emp1].[WORK_LOC_ADD_1]
      , [emp1].[WORK_LOC_ADD_2]
      , [emp1].[WORK_LOC_CITY]
      , [emp1].[WORK_LOC_STATE]
      , [emp1].[WORK_LOC_ZIP]
      , [emp1].[HOME_ADD_1]
      , [emp1].[HOME_ADD_2]
      , [emp1].[HOME_ADD_CITY]
      , [emp1].[HOME_ADD_STATE]
      , [emp1].[HOME_ADD_ZIP]
      , [emp1].[HOME_ADD_ST]
      , [emp1].[LOA]
      , [emp1].[REPORTS_TO]
      , [emp1].[REPORTS_TO_EMP_ID]
      , [emp1].[REPORTS_TO_EMAIL]
      , [emp1].[REPORTS_TO_MGR_LVL]
      , [emp1].[emp_rank]
      , [emp1].[MGR_LVL_NUM]
      , [emp1].[HIERARCHY_TIER]
      , [emp1].[TIER_1]
      , [emp1].[TIER_2]
      , [emp1].[TIER_3]
      , [emp1].[TIER_4]
      , [emp1].[TIER_5]
      , [emp1].[TIER_6]
      , [emp1].[Snapshot_FTE]
      , [emp1].[Period_FTE]
      , [emp1].[Info_Source]
      , [emp1].[Calendar_period]
    FROM
      [DateCriteria1] AS [emp1]
    )
    SELECT
      @Date1 AS RRD
      , [emp1].[EMP_ID]
      , [emp1].[JOB_REQ]
      , [emp1].[POS_NUM]
      , [emp1].[CANDIDATE_ID]
      , [emp1].[EMP_STATUS]
      , [emp1].[WORKER_TYPE]
      , [emp1].[CONT_SUP_NAME]
      , [emp1].[REMOTE_FLAG]
      , [emp1].[emp_NAME]
      , [emp1].[FIRST_NAME]
      , [emp1].[LAST_NAME]
      , [emp1].[RECENT_HIRE_DATE]
      , [emp1].[ORIG_HIRE_DATE]
      , [emp1].[DEPT_NUM]
      , [emp1].[DEPT_NAME]
      , [emp1].[FUNCTIONAL_GROUP]
      , [emp1].[PAY_TYPE]
      , [emp1].[JOB_TITLE]
      , [emp1].[JOB_CODE]
      , [emp1].[JOB_FAMILY]
      , [emp1].[JOB_GROUP]
      , [emp1].[JOB_FUNCTION]
      , [emp1].[WORK_PHONE]
      , [emp1].
      , [emp1].[EMP_MGR_LVL]
      , [emp1].[ANNUAL_RATE]
      , [emp1].[HRLY_RATE]
      , [emp1].[EMP_TYPE]
      , [emp1].[TIME_TYPE]
      , [emp1].[EXEMPT]
      , [emp1].[EXPECTED_HOURS]
      , [emp1].[COMP_GRADE]
      , [emp1].[WORK_LOC_ID]
      , [emp1].[WORK_LOC_NAME]
      , [emp1].[WORK_LOC_ADD_1]
      , [emp1].[WORK_LOC_ADD_2]
      , [emp1].[WORK_LOC_CITY]
      , [emp1].[WORK_LOC_STATE]
      , [emp1].[WORK_LOC_ZIP]
      , [emp1].[HOME_ADD_1]
      , [emp1].[HOME_ADD_2]
      , [emp1].[HOME_ADD_CITY]
      , [emp1].[HOME_ADD_STATE]
      , [emp1].[HOME_ADD_ZIP]
      , [emp1].[HOME_ADD_ST]
      , [emp1].[LOA]
      , [emp1].[REPORTS_TO]
      , [emp1].[REPORTS_TO_EMP_ID]
      , [emp1].[REPORTS_TO_EMAIL]
      , [emp1].[REPORTS_TO_MGR_LVL]
      , [emp1].[emp_rank]
      , [emp1].[MGR_LVL_NUM]
      , [emp1].[HIERARCHY_TIER]
      , [emp1].[TIER_1]
      , [emp1].[TIER_2]
      , [emp1].[TIER_3]
      , [emp1].[TIER_4]
      , [emp1].[TIER_5]
      , [emp1].[TIER_6]
      , [emp1].[Snapshot_FTE]
      , [emp1].[Period_FTE]
      , [emp1].[Info_Source]
      , [emp1].[Calendar_period]
    FROM
      [Diff1to2] AS [emp1]
    UNION
    SELECT
      @Date2 AS RRD
      , [emp2].[EMP_ID]
      , [emp2].[JOB_REQ]
      , [emp2].[POS_NUM]
      , [emp2].[CANDIDATE_ID]
      , [emp2].[EMP_STATUS]
      , [emp2].[WORKER_TYPE]
      , [emp2].[CONT_SUP_NAME]
      , [emp2].[REMOTE_FLAG]
      , [emp2].[emp_NAME]
      , [emp2].[FIRST_NAME]
      , [emp2].[LAST_NAME]
      , [emp2].[RECENT_HIRE_DATE]
      , [emp2].[ORIG_HIRE_DATE]
      , [emp2].[DEPT_NUM]
      , [emp2].[DEPT_NAME]
      , [emp2].[FUNCTIONAL_GROUP]
      , [emp2].[PAY_TYPE]
      , [emp2].[JOB_TITLE]
      , [emp2].[JOB_CODE]
      , [emp2].[JOB_FAMILY]
      , [emp2].[JOB_GROUP]
      , [emp2].[JOB_FUNCTION]
      , [emp2].[WORK_PHONE]
      , [emp2].
      , [emp2].[EMP_MGR_LVL]
      , [emp2].[ANNUAL_RATE]
      , [emp2].[HRLY_RATE]
      , [emp2].[EMP_TYPE]
      , [emp2].[TIME_TYPE]
      , [emp2].[EXEMPT]
      , [emp2].[EXPECTED_HOURS]
      , [emp2].[COMP_GRADE]
      , [emp2].[WORK_LOC_ID]
      , [emp2].[WORK_LOC_NAME]
      , [emp2].[WORK_LOC_ADD_1]
      , [emp2].[WORK_LOC_ADD_2]
      , [emp2].[WORK_LOC_CITY]
      , [emp2].[WORK_LOC_STATE]
      , [emp2].[WORK_LOC_ZIP]
      , [emp2].[HOME_ADD_1]
      , [emp2].[HOME_ADD_2]
      , [emp2].[HOME_ADD_CITY]
      , [emp2].[HOME_ADD_STATE]
      , [emp2].[HOME_ADD_ZIP]
      , [emp2].[HOME_ADD_ST]
      , [emp2].[LOA]
      , [emp2].[REPORTS_TO]
      , [emp2].[REPORTS_TO_EMP_ID]
      , [emp2].[REPORTS_TO_EMAIL]
      , [emp2].[REPORTS_TO_MGR_LVL]
      , [emp2].[emp_rank]
      , [emp2].[MGR_LVL_NUM]
      , [emp2].[HIERARCHY_TIER]
      , [emp2].[TIER_1]
      , [emp2].[TIER_2]
      , [emp2].[TIER_3]
      , [emp2].[TIER_4]
      , [emp2].[TIER_5]
      , [emp2].[TIER_6]
      , [emp2].[Snapshot_FTE]
      , [emp2].[Period_FTE]
      , [emp2].[Info_Source]
      , [emp2].[Calendar_period]
    FROM
      [Diff2to1] AS [emp2];
    GO
     

    Sorry Lynn, but that combined both dates of the data as a whole. I am searching for a way to do an exception. When the data doesn't match then show only the data that doesn't match.
    Thank you for trying.

  • Well, with nothing to test it against myself, I guess I will have to believe what you say.  Logically, however, I would disagree.  The first two CTEs should pull the necessary data for each date of the comparison.  The third CTE should pull all the data from the first set of data that doesn't exist in the second (the dates have been pulled as that would then return ALL the rows).  The fourth CTE does the reverse of the third pulling all the data from the second set that isn't in the first (again, not including the dates).  This means that the data in the third CTE is from the first data set and the data in the fourth CTE is from the second data set.  The dates for these sets are added back to the respective data sets and the data then UNIONed together.

  • If all you want are the data columns where data is different between two rows of data, which could mean different columns for different sets within the entire set, you may need to look at writing some pretty gnarly dynamic SQL as columns aren't going to align nicely.
    What I wrote should be returning only the data that differs between two sets of dates.  You would need to do additional work to identify the data columns where data differs.

  • I started to go about the self join differently, here is a snippet that works until you add the WORKER_TYPE which is the same in both sets so it then unfortunately doesn't display the EMP_STATUS or PERIOD_FTE anymore which didn't match and what I wanted it to display.
    I can added data to this once I leave for the day. It's a little tough right now to do at work.

    Select

    emp1.RRD RRD1,

    emp1.EMP_ID EMP_ID1,

    emp1.EMP_STATUS EMP_STATUS1,

    emp1.Period_FTE Period_FTE1,

    emp1.WORKER_TYPE WORKER_TYPE1,

    emp2.RRD RRD2,

    emp2.EMP_ID EMP_ID2,

    emp2.EMP_STATUS EMP_STATUS2,

    emp2.Period_FTE Period_FTE2,

    emp2.WORKER_TYPE WORKER_TYPE2

    INTO #EMPTEMP7

    FROM emp_main emp1, emp_main emp2

    WHERE emp1.rrd = '2018-06-04'

    and emp2.rrd = '2018-06-01'

    and emp1.emp_id = emp2.emp_id

    and emp1.EMP_STATUS <> emp2.EMP_STATUS

    and emp1.Period_FTE <> emp2.Period_FTE

    and emp1.WORKER_TYPE <> emp2.WORKER_TYPE

    ORDER

    BY RRD1, RRD2;

    

  • dc5jdmr - Tuesday, June 19, 2018 12:35 PM

    I started to go about the self join differently, here is a snippet that works until you add the WORKER_TYPE which is the same in both sets so it then unfortunately doesn't display the EMP_STATUS or PERIOD_FTE anymore which didn't match and what I wanted it to display.
    I can added data to this once I leave for the day. It's a little tough right now to do at work.

    Select

    emp1.RRD RRD1,

    emp1.EMP_ID EMP_ID1,

    emp1.EMP_STATUS EMP_STATUS1,

    emp1.Period_FTE Period_FTE1,

    emp1.WORKER_TYPE WORKER_TYPE1,

    emp2.RRD RRD2,

    emp2.EMP_ID EMP_ID2,

    emp2.EMP_STATUS EMP_STATUS2,

    emp2.Period_FTE Period_FTE2,

    emp2.WORKER_TYPE WORKER_TYPE2

    INTO #EMPTEMP7

    FROM emp_main emp1, emp_main emp2

    WHERE emp1.rrd = '2018-06-04'

    and emp2.rrd = '2018-06-01'

    and emp1.emp_id = emp2.emp_id

    and emp1.EMP_STATUS <> emp2.EMP_STATUS

    and emp1.Period_FTE <> emp2.Period_FTE

    and emp1.WORKER_TYPE <> emp2.WORKER_TYPE

    ORDER

    BY RRD1, RRD2;

    

    First of all, please use ANSI-02 style joins instead of the older ANSI-89 style joins.  This will separate your join criteria from your filter criteria.

    Try this:

    SELECT
      [emp1].[RRD]           [RRD1]
      , [emp1].[EMP_ID]      [EMP_ID1]
      , [emp1].[EMP_STATUS]  [EMP_STATUS1]
      , [emp1].[Period_FTE]  [Period_FTE1]
      , [emp1].[WORKER_TYPE] [WORKER_TYPE1]
      , [emp2].[RRD]         [RRD2]
      , [emp2].[EMP_ID]      [EMP_ID2]
      , [emp2].[EMP_STATUS]  [EMP_STATUS2]
      , [emp2].[Period_FTE]  [Period_FTE2]
      , [emp2].[WORKER_TYPE] [WORKER_TYPE2]
    INTO
      [#EMPTEMP7]
    FROM
      [emp_main] [emp1]
      INNER JOIN [emp_main] [emp2]
        ON [emp1].[emp_id]      = [emp2].[emp_id]
    WHERE
      ([emp1].[rrd]             = '2018-06-04'
      AND [emp2].[rrd]          = '2018-06-01')
      AND ([emp1].[EMP_STATUS]     <> [emp2].[EMP_STATUS]
           OR [emp1].[Period_FTE]  <> [emp2].[Period_FTE]
           OR [emp1].[WORKER_TYPE] <> [emp2].[WORKER_TYPE])
    ORDER BY
      [RRD1]
      , [RRD2];
    GO

  • This is good Lynn!

    Is there a way to have WORKER_TYPE not show if [emp1].[WORKER_TYPE] <> [emp2].[WORKER_TYPE] and EMP_STATUS  if [emp1].[EMP_STATUS] <> [emp2].[EMP_STATUS]not show? The Period_FTE columns are all different so those are good.

    the data displays as:

  • You would have to write some interesting dynamic SQL to return the entire data set, then determine if two columns between the two sets of data completely match and not include that data in the final result set.  The more columns of data that you need to report differences would make that dynamic SQL even harder to write and maintain in my opinion, and I have had to write some interesting dynamic SQL at times but nothing like what you are asking.

Viewing 13 posts - 1 through 12 (of 12 total)

You must be logged in to reply to this topic. Login to reply