Solved

Consolidate Codes and Dates in proper order

Posted on 2008-06-22
7
189 Views
Last Modified: 2011-10-19
I need to group a person with enterdates,entercodes,withdrawal dates and withdrawal codes in correct sequential (date) order. One person may have 10 records with sequential dates. See file. The 'Days Attended' field may not look right if you calculate the date diff...that's ok, I just need to put the number on the correct line for now. P.S. I don't create these files, just inherit them...
Thank you!

I started the query below, but don't have a clue how to put the E code & W codes on one line (see Results table example in xls file).
select a.lastname,a.firstname,a.middlename, effdate,entercode,leavecode,

DATEDIFF(day,effdate,

   (Select MIN(effdate) from Table1 b

    where b.lastname=a.lastname and b.firstname=a.firstname and b.effdate > a.effdate)) NoDays

from Table1 a

order by a.lastname,a.firstname,a.middlename

Open in new window

Enterdateleavedates.xls
0
Comment
Question by:lbarnett419
  • 6
7 Comments
 
LVL 12

Expert Comment

by:patrikt
ID: 21844383
I see your problem. There are two solution.
1) Use "fake" agregate. If you GROUP BY a.lastname,a.firstname,a.middlename, effdate you can use MAX(entercode), MAX(leavecode), MAX(DATEDIFF.....) because only other value is NULL and agregate skips nulls.

2) Better one. Convert subquery to JOIN and extract leave code there. I'll try to write it for you, give me a sec.

Patrik
0
 
LVL 12

Expert Comment

by:patrikt
ID: 21844459
There is my blind shot code.
Without testing I can only guess that it works. Test it and come back with result if you want.

BTW: Structure you have looks wery strange. Start thinking about database redesign if you want to avoid problems in future.

Patrik
select a.lastname,a.firstname,a.middlename, a.effdate,a.entercode,b.effdate), b.leavecode,

DATEDIFF(day,b.effdate,a.effdate) AS NoDays

from Table1 a

JOIN Table1 b

	ON  b.lastname=a.lastname and b.firstname=a.firstname and b.effdate =(SELECT MIN(effdate) FROM Table1 c WHERE c.effdate>a.effdate)

order by a.lastname,a.firstname,a.middlename

Open in new window

0
 

Author Comment

by:lbarnett419
ID: 21857950
I tried the query(THANK YOU!)  & changed the DATEDIFF(day,b.effdate,a.effdate) to (day,a.effdate,b.effdate) so the days would be positive days. Either way, I am only getting a subset of the records for each person. The John Smith record originally had:
LN      FN      EffDate      EnterCode      LeaveCode
Abbott      Joseph      11/13/2006      E      NULL
Abbott      Joseph      12/19/2006      NULL      W20
Abbott      Joseph      2/6/2007      E      NULL
Abbott      Joseph      2/16/2007      NULL      W10
Abbott      Joseph      2/19/2007      E      NULL
Abbott      Joseph      3/22/2007      NULL      W20

The query result was:
LN      FN      EffDate      EnterCode      EffDate      LeaveCode      NoofDays
Smith      John      2/16/2007      NULL      2/19/2007      NULL      3
Any ideas?
0
Microsoft Certification Exam 74-409

Veeam® is happy to provide the Microsoft community with a study guide prepared by MVP and MCT, Orin Thomas. This guide will take you through each of the exam objectives, helping you to prepare for and pass the examination.

 
LVL 12

Expert Comment

by:patrikt
ID: 21863404
I'll look on it.
But you send wrong example, mixed Joseph Abbot with John Smith.

Patrik
0
 
LVL 12

Expert Comment

by:patrikt
ID: 21864408
I think mz query is ok, but restriction on start row is missing.
I suppose Enter row has LeaveCode NULL and Leave row has EnterCode NULL.
Try this one:
select a.lastname,a.firstname,a.middlename, a.effdate,a.entercode,b.effdate), b.leavecode,

DATEDIFF(day,b.effdate,a.effdate) AS NoDays

from Table1 a

JOIN Table1 b

	ON  b.lastname=a.lastname and b.firstname=a.firstname and a.LeaveCode IS NULL AND b.effdate =(SELECT MIN(effdate) FROM Table1 c WHERE c.effdate>a.effdate AND c.LeaveCode IS NOT NULL)

order by a.lastname,a.firstname,a.middlename

Open in new window

0
 
LVL 12

Accepted Solution

by:
patrikt earned 500 total points
ID: 21864514
Or on SQL 2005 may better perform this one.
It is same only using new APPLY.
select a.lastname,a.firstname, a.effdate,a.entercode,b.effdate, b.leavecode,

DATEDIFF(day,b.effdate,a.effdate) AS NoDays

from Table1 a

OUTER APPLY (select TOP 1 c.lastname,c.firstname,c.effdate,c.leavecode FROM Table1 c 

	WHERE 

	c.lastname=a.lastname and c.firstname=a.firstname AND

	c.effdate>a.effdate and c.leavecode IS NOT NULL 

	ORDER BY c.effdate) b

WHERE a.entercode IS NOT NULL

order by a.effdate

Open in new window

0
 
LVL 12

Expert Comment

by:patrikt
ID: 22374711
Please write comment why it is graded B. What was wrong on solution?
0

Featured Post

Best Practices: Disaster Recovery Testing

Besides backup, any IT division should have a disaster recovery plan. You will find a few tips below relating to the development of such a plan and to what issues one should pay special attention in the course of backup planning.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Modifying SQL 2008/2012 PARTITIONS 3 55
Restrict result set 1 35
INSERT DATE FROM STRING COLUMN 18 50
Replace Dates in query 14 21
Introduction This article will provide a solution for an error that might occur installing a new SQL 2005 64-bit cluster. This article will assume that you are fully prepared to complete the installation and describes the error as it occurred durin…
When writing XML code a very difficult part is when we like to remove all the elements or attributes from the XML that have no data. I would like to share a set of recursive MSSQL stored procedures that I have made to remove those elements from …
This Micro Tutorial will give you a basic overview how to record your screen with Microsoft Expression Encoder. This program is still free and open for the public to download. This will be demonstrated using Microsoft Expression Encoder 4.
Hi friends,  in this video  I'll show you how new windows 10 user can learn the using of windows 10. Thank you.

863 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

19 Experts available now in Live!

Get 1:1 Help Now