Order question
Hey guys, another strange question here..
If I query and order by a field and there are duplicate values in that
field, what makes one return before the other? Just the first one that PG
comes to on the disk is displayed first or is something else looked at to
determine the order?
Example :
hhs=# SELECT ordernum,fieldname,oid from resultstyle WHERE style_id=1001
order by ordernum asc;
ordernum | fieldname | oid
----------+---------------+---------
1 | J.jobtitle | 1197126
1 | J.inv_id | 1197125
2 | J.updatedon | 1197127
3 | J.empinitials | 1197128
What makes the record with j.jobtitle appear above te other, when ordernum
is the same?
Thanks!
-Mitch
A further extension of this..
What might I be able to additionally order by so that the most recently
updated rows get ordered above everything else (within the order by
ordernum).. Using the same example :
ordernum | fieldname | oid
----------+---------------+---------
1 | J.jobtitle | 1197126
1 | J.inv_id | 1197125
2 | J.updatedon | 1197127
3 | J.empinitials | 1197128
I just set the row with j.inv_id to 1, I'd like it to be ordered above the
row with j.jobtitle in it -- is that possible?
Thanks again!
-Mitch
----- Original Message -----
From: "Mitch Vincent" <mitch@venux.net>
To: <pgsql-general@postgresql.org>
Sent: Tuesday, February 13, 2001 5:54 PM
Subject: Order question
Show quoted text
Hey guys, another strange question here..
If I query and order by a field and there are duplicate values in that
field, what makes one return before the other? Just the first one that PG
comes to on the disk is displayed first or is something else looked at to
determine the order?Example :
hhs=# SELECT ordernum,fieldname,oid from resultstyle WHERE style_id=1001
order by ordernum asc;
ordernum | fieldname | oid
----------+---------------+---------
1 | J.jobtitle | 1197126
1 | J.inv_id | 1197125
2 | J.updatedon | 1197127
3 | J.empinitials | 1197128What makes the record with j.jobtitle appear above te other, when ordernum
is the same?Thanks!
-Mitch
On Tue, Feb 13, 2001 at 05:58:35PM -0500, Mitch Vincent wrote:
I just set the row with j.inv_id to 1, I'd like it to be ordered above the
row with j.jobtitle in it -- is that possible?
make a trigger that updates a time stamp and order by that?
mrc
--
Mike Castle Life is like a clock: You can work constantly
dalgoda@ix.netcom.com and be right all the time, or not work at all
www.netcom.com/~dalgoda/ and be right at least twice a day. -- mrc
We are all of us living in the shadow of Manhattan. -- Watchmen
Mitch Vincent wrote:
A further extension of this..
What might I be able to additionally order by so that the most recently
updated rows get ordered above everything else (within the order by
ordernum).. Using the same example :ordernum | fieldname | oid
----------+---------------+---------
1 | J.jobtitle | 1197126
1 | J.inv_id | 1197125
2 | J.updatedon | 1197127
3 | J.empinitials | 1197128I just set the row with j.inv_id to 1, I'd like it to be ordered above the
row with j.jobtitle in it -- is that possible?
Add a column with a timestamp. Then, in the update/insert, make the
timestamp equal the current time. Then ORDER BY ordernum, timestamp.
Or better, modify the other ordernums, as you have an ambiguous
situation with two ordernums being equal. Writing that in a single
UPDATE would be left as an exercise for the reader :-).
--
Lamar Owen
WGCR Internet Radio
1 Peter 4:11
Sure, I was just wondering if there was some PG internal value I could use
(and I should have said that in my email)..
Thanks for the suggestion though, I appreciate it..
-Mitch
----- Original Message -----
From: "Mike Castle" <dalgoda@ix.netcom.com>
To: <pgsql-general@postgresql.org>
Sent: Tuesday, February 13, 2001 6:18 PM
Subject: Re: Re: Order question
On Tue, Feb 13, 2001 at 05:58:35PM -0500, Mitch Vincent wrote:
I just set the row with j.inv_id to 1, I'd like it to be ordered above
the
Show quoted text
row with j.jobtitle in it -- is that possible?
make a trigger that updates a time stamp and order by that?
mrc
--
Mike Castle Life is like a clock: You can work constantly
dalgoda@ix.netcom.com and be right all the time, or not work at all
www.netcom.com/~dalgoda/ and be right at least twice a day. -- mrc
We are all of us living in the shadow of Manhattan. -- Watchmen
"Mitch Vincent" <mitch@venux.net> writes:
I just set the row with j.inv_id to 1, I'd like it to be ordered above the
row with j.jobtitle in it -- is that possible?
Not unless you add a field with an update sequence number, or some such,
and then explicitly use that field as a second ORDER BY key. The system
does not maintain anything like that for you --- and should not, IMHO,
since it'd be useless overhead for apps that didn't care.
regards, tom lane
I suppose you could use the oid column as long as it was not wrapping
(starting to count over).
Joseph
Show quoted text
-----Original Message-----
From: pgsql-general-owner@postgresql.org
[mailto:pgsql-general-owner@postgresql.org]On Behalf Of Mitch Vincent
Sent: Tuesday, February 13, 2001 6:24 PM
To: Mike Castle; pgsql-general@postgresql.org
Subject: [GENERAL] Re: Re: Order questionSure, I was just wondering if there was some PG internal value I could use
(and I should have said that in my email)..Thanks for the suggestion though, I appreciate it..
-Mitch
----- Original Message -----
From: "Mike Castle" <dalgoda@ix.netcom.com>
To: <pgsql-general@postgresql.org>
Sent: Tuesday, February 13, 2001 6:18 PM
Subject: Re: Re: Order questionOn Tue, Feb 13, 2001 at 05:58:35PM -0500, Mitch Vincent wrote:
I just set the row with j.inv_id to 1, I'd like it to be ordered above
the
row with j.jobtitle in it -- is that possible?
make a trigger that updates a time stamp and order by that?
mrc
--
Mike Castle Life is like a clock: You can work constantly
dalgoda@ix.netcom.com and be right all the time, or not work at all
www.netcom.com/~dalgoda/ and be right at least twice a day. -- mrc
We are all of us living in the shadow of Manhattan. -- Watchmen