Solved

A difficult SQL query

Posted on 2007-11-28
7
561 Views
Last Modified: 2011-04-14
I have a table like following, it has three columns:
ID          Status                Date
1             13        3/8/2007 18:55:58
2             14        3/9/2007 19:00:00
3             13        3/10/2007 19:00:00
4             13        3/11/2007  19:00:00
I want to make a sql query to get the following record:
status 13 insert to table after status 14(base on date column), such as ID 3 record  in above sample table.
and if the lastest record is not 14, like row 4, the lastest record is 13, so row 4 shouldn't be selected.
In sample table, only row 3 should be selected.
I am not sure I have explained it very clear, pls. help me. Thanks a lot!
btw, server is sql-server, so t-sql can be used.
0
Comment
Question by:d_chenxin
7 Comments
 

Expert Comment

by:JakeAnvil
ID: 20364007
It is a bit tricky to understand. I suggest you make up a table of data that should be retrieved by the query in subject. Just the way you typed in the initial data table in your question. More details on what you want to accomplish could be helpfull, too.
0
 
LVL 9

Expert Comment

by:auke_t
ID: 20364039
Something like this I think:
SELECT
	*
FROM
	yourtable t3
WHERE
	t3.[date] in
(
SELECT
	(SELECT min(t2.[date]) FROM yourtable t2 WHERE t2.[date] > t1.[date]
FROM
	yourtable t1
WHERE
	status = 14
)
AND
	status = 13

Open in new window

0
 
LVL 6

Expert Comment

by:Rajesh_mj
ID: 20364040

SELECT ID,Status,DATE from
MyTable M where M.ID >=
 (Select min(id) from Mytable M1 where M1.Status = 
(select Max(M2.Status) from MyTable M2))

Open in new window

0
 
LVL 9

Accepted Solution

by:
auke_t earned 500 total points
ID: 20364053
Forgot one )
CREATE TABLE #yourtable
(
ID integer,
Status integer,
Date DATETIME
)
INSERT INTO #yourtable VALUES (1, 13, '3/8/2007 18:55:58')
INSERT INTO #yourtable VALUES (2, 14, '3/9/2007 19:00:00')
INSERT INTO #yourtable VALUES (3, 13, '3/10/2007 19:00:00')
INSERT INTO #yourtable VALUES (4, 13, '3/11/2007  19:00:00')
 
SELECT
	*
FROM
	#yourtable t3
WHERE
	t3.[date] in
(
SELECT
	(SELECT min(t2.[date]) FROM #yourtable t2 WHERE t2.[date] > t1.[date]) 
FROM
	#yourtable t1
WHERE
	status = 14
)
AND
	status = 13

Open in new window

0
 

Author Comment

by:d_chenxin
ID: 20370591
Hi auke_t,

Thank you so much for your solution, it's very good!
I want to accept your solution, but it always shows an error: EmailTemplateTag not found (Tag: GRADING_COMMENTS)
So do you know what's wrong with me? Thanks!
0

Featured Post

The Eight Noble Truths of Backup and Recovery

How can IT departments tackle the challenges of a Big Data world? This white paper provides a roadmap to success and helps companies ensure that all their data is safe and secure, no matter if it resides on-premise with physical or virtual machines or in the cloud.

Question has a verified solution.

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

In this article I will describe the Backup & Restore method as one possible migration process and I will add the extra tasks needed for an upgrade when and where is applied so it will cover all.
I have a large data set and a SSIS package. How can I load this file in multi threading?
Via a live example, show how to extract insert data into a SQL Server database table using the Import/Export option and Bulk Insert.
Using examples as well as descriptions, and references to Books Online, show the documentation available for datatypes, explain the available data types and show how data can be passed into and out of variables.

770 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