Re: Selecting rows as if they were columns?
От | Harald Fuchs |
---|---|
Тема | Re: Selecting rows as if they were columns? |
Дата | |
Msg-id | pun0cattqk.fsf@srv.protecting.net обсуждение исходный текст |
Ответ на | Selecting rows as if they were columns? (Kurt Overberg <kurt@hotdogrecords.com>) |
Список | pgsql-sql |
In article <3F855F38.9070803@hotdogrecords.com>, Kurt Overberg <kurt@hotdogrecords.com> writes: > Gang, > I've got what I think should be a pretty simple problem- I just can't > figure out how I'd do it. Heck, I can't even figure out how I'd > search for an answer to this problem. > I've got 2 tables: member and member_attr > Member is just a standard entry for a member. Very simple: > table member { > id integer, > name character varying(30) > } > Member_attr is just a table of name/value pairs, such as: > table memberextra { > memberid integer, > param1 character varying(512), > param2 character varying(512), > } > where param1 is the name, param2 is the value. > Right now, I can: > select member.id, member.name, member_attr.param1, member_attr.param2 > from member, member_attr where member.id = member_attr.memberid; > ...this gives me n rows per member where n = # of attributes for that > member, like this: > id | name | param1 | param2 > ======================================= > 1 | dave | home | /home/dave > 1 | dave | testing | 1 > 2 | john | home | /home/john > ...is there some way to make this return like this: > id | name | home | testing > ====================================== > 1 | dave | /home/dave | 1 > 2 | john | /home/john | > ...where it sort of "expands" the rows out into columns? Am I just > going about this the wrong way? Thoughts on the subject would be > greatly appreciated. This should work fine as long as you know all possible values of param1 in advance: SELECT m.id, m.name, m1.param2, m2.param2 FROM member m LEFT JOIN memberextra m1 ON m1.memberid = m.id AND m1.param1 = 'home' LEFT JOIN memberextra m2 ON m2.memberid = m.id AND m2.param1 = 'testing'
В списке pgsql-sql по дате отправления: