Re: Group by a range of values

From: Samed YILDIRIM <samed(at)reddoc(dot)net>
To: Torsten Grust <torsten(dot)grust(at)gmail(dot)com>, pgsql-sql <pgsql-sql(at)lists(dot)postgresql(dot)org>
Subject: Re: Group by a range of values
Date: 2020-08-08 11:29:35
Message-ID: 615631596886135@mail.yandex.com.tr
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

<div><div>Hi,</div><div> </div><div>Another (and less optimised :)) alternative;</div><div> </div><div><div>pgsql-sql=# select m,dense_rank() over (order by (m-1)/3) from generate_series(1,10) m;</div><div>m | dense_rank</div><div>----+------------</div><div>1 | 1</div><div>2 | 1</div><div>3 | 1</div><div>4 | 2</div><div>5 | 2</div><div>6 | 2</div><div>7 | 3</div><div>8 | 3</div><div>9 | 3</div><div>10 | 4</div><div>(10 rows)</div><div> </div></div></div><div>Best regards.</div><div>Samed YILDIRIM</div><div> </div><div> </div><div> </div><div>01.08.2020, 15:35, "Torsten Grust" &lt;torsten(dot)grust(at)gmail(dot)com&gt;:</div><blockquote><div><div style="font-family:'arial' , sans-serif"><div style="font-family:'arial' , sans-serif">Hi,</div><div style="font-family:'arial' , sans-serif"> </div><div style="font-family:'arial' , sans-serif">maybe this does the job already (/ is integer division):</div><div style="font-family:'arial' , sans-serif"> </div><div style="font-family:'arial' , sans-serif">SELECT i, 1 + (i-1) / 3 </div><div style="font-family:'arial' , sans-serif">FROM   generate_series(1,10) AS i;</div><div style="font-family:'arial' , sans-serif"> </div><div style="font-family:'arial' , sans-serif">An expression like (i-1) / 3 could, of course, also be used as partitioning criterion in GROUP BY and/or window functions.</div><div style="font-family:'arial' , sans-serif"> </div><div style="font-family:'arial' , sans-serif">Cheers,</div><div style="font-family:'arial' , sans-serif">  —T</div></div></div> <div><div>On Sat, Aug 1, 2020 at 2:15 PM Mike Martin &lt;<a href="mailto:redtux1(at)gmail(dot)com">redtux1(at)gmail(dot)com</a>&gt; wrote:</div><blockquote style="border-left-color:rgb( 204 , 204 , 204 );border-left-style:solid;border-left-width:1px;margin:0px 0px 0px 0.8ex;padding-left:1ex"><div><div>Say I have a field of ints, as for example created by with ordinality or generate_series, is it possible to group by a range? eq</div><div> </div><div>1,2,3,4,5,6,7,8,9,10</div><div>step 3</div><div>so output is</div><div> </div><div>1 1</div><div>2 1</div><div>3 1</div><div>4 2</div><div>5 2</div><div>6 2</div><div>7 3</div><div>8 3</div><div>9 3</div><div>10 4</div><div> </div><div>thanks</div></div></blockquote></div> <div> </div>--<div><div><div><div><div><font face="monospace, monospace">| Torsten Grust<br />| <a href="mailto:Torsten(dot)Grust(at)gmail(dot)com">Torsten(dot)Grust(at)gmail(dot)com</a></font><br /> </div></div></div></div></div></blockquote>

Attachment Content-Type Size
unknown_filename text/html 2.4 KB

In response to

Browse pgsql-sql by date

  From Date Subject
Next Message ml 2020-08-09 06:28:44 recursive sql
Previous Message Mike Martin 2020-08-03 10:39:11 Error - Arrays must contain only scalars and other arrays when array element is an array