On Fri, Jul 3, 2009 at 8:32 PM, Guy Flaherty <naosh...@gmail.com> wrote:

>
>
> On Fri, Jul 3, 2009 at 7:44 PM, Jennifer Trey <jennifer.t...@gmail.com>wrote:
>
>> Hi,
>>
>> I would like to run a query and group several rows based on a phone
>> number.
>>
>> However, the same phone number might have a prefix on occasion, example :
>>
>> name | phone_number
>> ----------------------
>> james | 123456
>> james | 00441234556
>> james | 555666
>> sarah | 567890
>> sarah | 567890
>>
>> as you can see, the first 2 James seems to belong together.
>>
>> running
>>
>> select name, phone_number from relation group by name, phone_number
>>
>> would not reflect this.
>>
>> I don't think there is a way to run something similar to this :
>>
>> select name, phone_number from relation group by name, %phone_number%
>> // or similar
>>
>> However, I believe there is a way, so I would like to here it from you :)
>>
>> Functions, sums .. please let me know..
>>
>> Thank you in advance / Jennifer
>
>
> You could run a sub-select first to get your results and then group on
> that, such as:
>
> SELECT name, pn
> FROM
> (SELECT name, substring(phone_number from length(phone_number)-7) AS pn
> FROM relation
> WHERE phone_number LIKE '%1234%') AS r
> GROUP BY name,pn
>

Blah, having said that, you are probably looking for something more like
this:

SELECT "name", substring(phone_number from length(phone_number)-7) AS pn
FROM relation
GROUP BY name,2

GF

Reply via email to