Solved

A difficult SQL query

Posted on 2007-11-28
7
555 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
Comment Utility
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
Comment Utility
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
Comment Utility

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
Comment Utility
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
Comment Utility
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

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
The Delta outage: 650 cancelled flights, more than 1200 delayed flights, thousands of frustrated customers, tens of millions of dollars in damages – plus untold reputational damage to one of the world’s most trusted airlines. All due to a catastroph…
This video shows, step by step, how to configure Oracle Heterogeneous Services via the Generic Gateway Agent in order to make a connection from an Oracle session and access a remote SQL Server database table.
Viewers will learn how to use the SELECT statement in SQL to return specific rows and columns, with various degrees of sorting and limits in place.

762 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

9 Experts available now in Live!

Get 1:1 Help Now