Since you very nicely DID NOT provide the pg version, O/S or table
structure(s), which is what you should do REGARDLESS of the
type of question (it's just the smart and polite thing to do when asking
for help) The best  I can suggest is:
SELECT
  CASE WHEN context = 'friend' THEN p.junka
            WHEN context = 'group' THEN p.junkb
            WHEN context = 'both'   THEN p.junka || ' ' || p.junkb
    END
   FROM posting p
  where p.author_id in (SELECT f.friend_id
                                    FROM friends f
                                  WHERE f.user_id = ?)
       OR p.group_id in (SELECT m.group_id
                                    FROM memberships m
                                  WHERE m.user_id = ?);


On Tue, Apr 28, 2015 at 6:26 PM, Jonathan Vanasco <postg...@2xlp.com> wrote:

>
> I'm trying to upgrade some code that powers a newfeed type stream, and
> hoping someone can offer some insight on better ways to structure some
> parts of the query
>
> The part that has me stumped right now...
>
> There are several criteria for why something could appear in a stream.
> for example, here are 2 handling a posting:
>
>         * a posting by a friend
>         * a posting in a group
>
> the general way I've handled this so far has been simple:
>
>         select * from posting where author_id in (select friend_id from
> friends where user_id = ?) or group_id in (select group_id from memberships
> where user_id = ?);
>
> now i need to pull in the context of the match (friend, group, both), but
> I can't figure out how to do this cleanly.
>
> 1. if i just add 'case' statements to the select to note the origin, those
> subselects run again.   (ie, the same subquery is executed twice)
> 2. if i structure this as a union (and note the origin with a string), it
> takes a lot more work to integrate and sort the 2 separate selects ( eg
> "select id, timestamp, 'by-friend'" unioned with "in-group")
>
> does anyone have ideas on other approaches to structuring this?
>
>
>
>
>
>
>
>
>
>
>
>
> --
> Sent via pgsql-general mailing list (pgsql-general@postgresql.org)
> To make changes to your subscription:
> http://www.postgresql.org/mailpref/pgsql-general
>



-- 
*Melvin Davidson*
I reserve the right to fantasize.  Whether or not you
wish to share my fantasy is entirely up to you.

Reply via email to