473,386 Members | 1,647 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,386 software developers and data experts.

SQL Question

Hello,

DB2 V8 LUW.

I have a simple table A with fields ID and SESSION_NUMBER (integer).
One ID can have multiple session numbers.

For a given ID, I can find the last two sessions with a simple SQL:

select * from table where ID='xyz' order by SESSION_NUMBER desc fetch
first two rows only

This may be rather simple, but I am stuck:

How do I return only the last two sessions for each ID that this table
has?

TIA, Michel

Feb 15 '07 #1
4 1665
Just did something similar. Look up the OLAP rownumber() function.
Partition by your ID field and order by your SESSION_NUMBER
descending. Feed the results of this to an outer query and look for
rows having a rownumber of 2 or less. Something like:

select id, session_number
from (
select id, session_number, rownumber() over (partition by id order
by sess desc) as rn
from table_A
) as tt
where tt.rn <=2
HTH,
Mike
On Feb 15, 2:23 pm, "Michel Esber" <mic...@us.automatos.comwrote:
Hello,

DB2 V8 LUW.

I have a simple table A with fields ID and SESSION_NUMBER (integer).
One ID can have multiple session numbers.

For a given ID, I can find the last two sessions with a simple SQL:

select * from table where ID='xyz' order by SESSION_NUMBER desc fetch
first two rows only

This may be rather simple, but I am stuck:

How do I return only the last two sessions for each ID that this table
has?

TIA, Michel

Feb 15 '07 #2
On Feb 15, 12:23 pm, "Michel Esber" <mic...@us.automatos.comwrote:
Hello,

DB2 V8 LUW.

I have a simple table A with fields ID and SESSION_NUMBER (integer).
One ID can have multiple session numbers.

For a given ID, I can find the last two sessions with a simple SQL:

select * from table where ID='xyz' order by SESSION_NUMBER desc fetch
first two rows only

This may be rather simple, but I am stuck:

How do I return only the last two sessions for each ID that this table
has?

TIA, Michel
select * from table a
where SESSION_NUMBER in
(select b.SESSION_NUMBER from table b
where b.ID = a.ID
order by b.SESSION_NUMBER desc
fetch first 2 rows only)

Feb 16 '07 #3
On 15 Feb 2007 11:23:05 -0800, "Michel Esber"
<mi****@us.automatos.comwrote:
>Hello,

DB2 V8 LUW.

I have a simple table A with fields ID and SESSION_NUMBER (integer).
One ID can have multiple session numbers.

For a given ID, I can find the last two sessions with a simple SQL:

select * from table where ID='xyz' order by SESSION_NUMBER desc fetch
first two rows only

This may be rather simple, but I am stuck:

How do I return only the last two sessions for each ID that this table
has?

TIA, Michel
By adding a DATE COLUMN, then use ORDER BY. Without an ORDER BY in the
query, there is no real order, and the results may change in between
executions.

B.
Feb 16 '07 #4
On Feb 16, 8:04 am, Brian Tkatch <N/Awrote:
>
By adding a DATE COLUMN, then use ORDER BY. Without an ORDER BY in the
query, there is no real order, and the results may change in between
executions.
I think it is reasonable to assume that the SESSION_NUMBER is assigned
sequentially for each ID, and the two highest values are the last two
inserted for a given ID.

Feb 16 '07 #5

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

1
by: Mohammed Mazid | last post by:
Can anyone please help me on how to move to the next and previous question? Here is a snippet of my code: Private Sub cmdNext_Click() End Sub Private Sub cmdPrevious_Click() showrecord
3
by: Stevey | last post by:
I have the following XML file... <?xml version="1.0"?> <animals> <animal> <name>Tiger</name> <questions> <question index="0">true</question> <question index="1">true</question> </questions>
7
by: nospam | last post by:
Ok, 3rd or is it the 4th time I have asked this question on Partial Types, so, since it seems to me that Partial Types is still in the design or development stages at Microsoft, I am going to ask...
3
by: Ekqvist Marko | last post by:
Hi, I have one Access database table including questions and answers. Now I need to give answer id automatically to questionID column. But I don't know how it is best (fastest) to do? table...
10
by: glenn | last post by:
I am use to programming in php and the way session and post vars are past from fields on one page through to the post page automatically where I can get to their values easily to write to a...
10
by: Rider | last post by:
Hi, simple(?) question about asp.net configuration.. I've installed ASP.NET 2.0 QuickStart Sample successfully. But, When I'm first start application the follow message shown. ========= Server...
53
by: Jeff | last post by:
In the function below, can size ever be 0 (zero)? char *clc_strdup(const char * CLC_RESTRICT s) { size_t size; char *p; clc_assert_not_null(clc_strdup, s); size = strlen(s) + 1;
56
by: spibou | last post by:
In the statement "a *= expression" is expression assumed to be parenthesized ? For example if I write "a *= b+c" is this the same as "a = a * (b+c)" or "a = a * b+c" ?
2
by: Allan Ebdrup | last post by:
Hi, I'm trying to render a Matrix question in my ASP.Net 2.0 page, A matrix question is a question where you have several options that can all be rated according to several possible ratings (from...
3
by: Zhang Weiwu | last post by:
Hello! I wrote this: ..required-question p:after { content: "*"; } Corresponding HTML: <div class="required-question"><p>Question Text</p><input /></div> <div...
0
by: taylorcarr | last post by:
A Canon printer is a smart device known for being advanced, efficient, and reliable. It is designed for home, office, and hybrid workspace use and can also be used for a variety of purposes. However,...
0
by: aa123db | last post by:
Variable and constants Use var or let for variables and const fror constants. Var foo ='bar'; Let foo ='bar';const baz ='bar'; Functions function $name$ ($parameters$) { } ...
0
by: ryjfgjl | last post by:
If we have dozens or hundreds of excel to import into the database, if we use the excel import function provided by database editors such as navicat, it will be extremely tedious and time-consuming...
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.