Re: How to unnest an array with element indexes - Mailing list pgsql-sql

From David Johnston
Subject Re: How to unnest an array with element indexes
Date
Msg-id 1392838343105-5792771.post@n5.nabble.com
Whole thread Raw
In response to How to unnest an array with element indexes  (AlexK <alkuzo@gmail.com>)
Responses Re: How to unnest an array with element indexes
List pgsql-sql
AlexK wrote
> Given an array such as ARRAY[1.1,1.2], I need to select both values and
> indexes, as follows:
> 
> 1;1.1
> 2;1.2
> 
> The following query does what I want for a simple example:
> 
> with pivoted_array AS(
> select unnest(ARRAY[1.1,1.2])
> )
> select ROW_NUMBER() OVER() AS element_index, unnest as element_value
> from pivoted_array
> 
> Is ROW_NUMBER() OVER() guaranteed to always return array's index? If not,
> how should I predictably/deterministically do it?

9.4 will provide for this capability directly.  For earlier releases as long
as the next and only thing you do after unnesting the array is apply the
window function the order will be consistent - the rows will be seen by the
window in array order.  You must not perform any other joins until the row
numbers have been assigned.  It is best to use a pair of CTE/WITH queries to
accomplish this and then use the result of the second CTE in the main query.

If your need is much more complicated than the simple example provided you
may wish to give something more close to your actual need for some to opine
on.

David J.







--
View this message in context:
http://postgresql.1045698.n5.nabble.com/How-to-unnest-an-array-with-element-indexes-tp5792770p5792771.html
Sent from the PostgreSQL - sql mailing list archive at Nabble.com.



pgsql-sql by date:

Previous
From: AlexK
Date:
Subject: How to unnest an array with element indexes
Next
From: AlexK
Date:
Subject: Re: How to unnest an array with element indexes