SQL - 计算列中出现的次数

时间:2013-02-12 00:24:14

标签: sql sql-server sql-server-2008

我有一张表格如下:

我想在PageURL列中计算说“ab”和“cd”的出现次数。

ID  User  Activity  PageURL  Date
 1  Me    act1      abcd     2013-01-01
 2  Me    act2      cdab     2013-01-02
 3  You   act2      xyza     2013-02-02
 4  Me    act3      xyab     2013-01-03

我希望有2列...... 1表示“ab”,1表示“cd”。

在上面的例子中,“ab”的计数为3,“cd”的计数为2。

3 个答案:

答案 0 :(得分:7)

类似的东西:

select 
   CountAB = sum(case when PageURL like '%ab%' then 1 else 0 end),
   CountCD = sum(case when PageURL like '%cd%' then 1 else 0 end)
from
  MyTable
where
   PageURL like '%ab%' or
   PageURL like '%cd%'

这假设“ab”和“cd”只需要每行计算一次。此外,它可能效率不高。

答案 1 :(得分:3)

select
  (select count(*) as AB_Count from MyTable where PageURL like '%ab%') as AB_Count,
  (select count(*) as CD_Count from MyTable where PageURL like '%cd%') as CD_Count

答案 2 :(得分:0)

SELECT total1, total2 
    FROM (SELECT count(*) as total1 FROM table WHERE PageUrl LIKE '%ab%') tmp1,
         (SELECT count(*) as total2 FROM table WHERE PageUrl LIKE '%cd%') tmp2