|  | Posted by Erland Sommarskog on 06/11/56 11:58 
(muzili@gmail.com) writes:> I have two tables, one is about member infomations, the other is the
 > catergories
 > member_info(id,name,email,phone)
 > member_categories(id,category)
 >
 > how can create a view like this (id, name, category1, category2,
 > category3) with high performance?
 
 SELECT m.id, m.name,
 MIN (CASE mc.rowno WHEN 1 THEN mc.category END),
 MIN (CASE mc.rowno WHEN 2 THEN mc.category END),
 MIN (CASE mc.rowno WHEN 3 THEN mc.category END)
 FROM   member_info m
 JOIN   (SELECT id, category,
 rowno = row_number() OVER (PARTITION BY id ORDER BY category)
 FROM   member_categories) AS mc OM m.id = mc.id
 WHERE   mc.rowno <= 3
 GROUP   BY m.id, m.name
 
 This solution requires SQL 2005. It's difficult do this in one query in
 SQL 2000 and get performance with high volumes.
 
 
 
 
 --
 Erland Sommarskog, SQL Server MVP, esquel@sommarskog.se
 
 Books Online for SQL Server 2005 at
 http://www.microsoft.com/technet/prodtechnol/sql/2005/downloads/books.mspx
 Books Online for SQL Server 2000 at
 http://www.microsoft.com/sql/prodinfo/previousversions/books.mspx
  Navigation: [Reply to this message] |