首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Server中按3列进行分组并获得计数?

如何在Server中按3列进行分组并获得计数?
EN

Stack Overflow用户
提问于 2015-07-11 06:33:39
回答 2查看 47关注 0票数 1

我正在尝试创建一些按三列分组的SQL,然后获取形成分组结果的行的COUNT

而且,首先,由最高的数来排序。

我创建了一个SqlFiddle来帮我。

表模式(简化):

代码语言:javascript
复制
CREATE TABLE [dbo].[Foo]
(
    [FooId] [int] IDENTITY(1,1) NOT NULL,
    [CreatedOn] [datetime] NOT NULL,
    [Company] [varchar](20) NOT NULL,
    [ProductFirstname] [varchar](100) NOT NULL,
    [ProductLastname] [varchar](100) NOT NULL
)

样本数据:

代码语言:javascript
复制
INSERT INTO Foo VALUES ('2001-10-01T07:07:07', 'Red', 'Yummy', 'GummyBear');
INSERT INTO Foo VALUES ('2002-10-01T07:07:07', 'Red', 'Yummy', 'GummyBear');
INSERT INTO Foo VALUES ('2003-10-01T07:07:07', 'Red', 'Bannana', 'Cake');
INSERT INTO Foo VALUES ('2003-11-11T07:07:07', 'Red', 'Green', 'Apples');
INSERT INTO Foo VALUES ('2004-10-01T07:07:07', 'Red', 'Yummy', 'GummyBear');
INSERT INTO Foo VALUES ('2005-10-01T07:07:07', 'Blue', 'Yummy', 'GummyBear');
INSERT INTO Foo VALUES ('2006-10-01T07:07:07', 'Blue', 'Yummy', 'GummyBear');
INSERT INTO Foo VALUES ('2007-10-01T07:07:07', 'Blue', 'Yummy', 'GummyBear');
INSERT INTO Foo VALUES ('2008-10-01T07:07:07', 'Red', 'Yummy', 'GummyBear');
INSERT INTO Foo VALUES ('2009-10-01T07:07:07', 'Blue', 'Green', 'Apples');

预期结果:

代码语言:javascript
复制
+-----------------------------------+
| Company | Name            | Count |
+-----------------------------------+
|    Red   | Yummy GummyBear | 4    |
|   Blue   | Yummy GummyBear | 3    |
|    Red   | Bannana Cake    | 1    |
|    Red   | Green Apples    | 1    |
|   Blue   | Green Apples    | 1    |
+-----------------------------------+

因此,对于这些数据,CreatedOn基本上被忽略了。这是另一种用途的元数据。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-07-11 06:36:24

这就是你要找的:

代码语言:javascript
复制
SELECT 
    Company
    , ISNULL(ProductFirstname, '') + ' ' + ISNULL(ProductLastName, '') NAME
    , COUNT(*) Count
FROM foo
GROUP BY Company
    ,ISNULL(ProductFirstname, '') + ' ' + ISNULL(ProductLastName, '')
ORDER BY 3 DESC

这是一个工作的SQLFiddle

票数 4
EN

Stack Overflow用户

发布于 2015-07-11 06:41:14

试着跟着,

代码语言:javascript
复制
Select company, name, count(*) as count from
(
select
  company,
  (ProductFirstname + ProductLastName) as name,
from foo
)T 
group by company, name
Order by 3 desc
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31354213

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档