Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people, just like you, are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
Solved

SQL - How to do percent to total for each groups of record

Posted on 2012-03-26
4
451 Views
Last Modified: 2012-03-27
I have the following dataset

Fund |  FundID | Unit | Price | Mkt Value
----------------------------------------------------------
ABC        123             1         10               10        
ABC        123             1         20               20    
ABC         456            1         30               30
DEF          456            1         40               40
DEF          789            1         50               50
XYZ          789            1         60               60
XYZ          123            1         70               70
XYZ          456            1         80               80

I would like to manipulate to get

FundID  | Subtotal |Percent Total
-------------------------------------------------
123               100               27.78
456               150               41.67
789               110               31.55

Can it possible to write a SQL statement to do this?
0
Comment
Question by:tommym121
  • 2
4 Comments
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 37769502
Something like this:

;WITH    MyCTE
          AS (SELECT    FundID,
                        SUM(Price) SubTotal
              FROM      YourTable
              GROUP BY  FundID
             )
    SELECT  c1.FundID,
            c1.SubTotal,
            (c1.SubTotal * 100.0) / c2.Total
    FROM    MyCTE c1
            CROSS JOIN (SELECT  SUM(SubTotal) Total
                        FROM    MyCTE
                       ) c2

Open in new window

0
 
LVL 75

Accepted Solution

by:
Anthony Perkins earned 500 total points
ID: 37769507
This is how I tested it:

DECLARE @Table TABLE
    (
     Fund char(3) NOT NULL,
     FundID smallint NOT NULL,
     Unit tinyint NOT NULL,
     Price tinyint NOT NULL,
     MktValue tinyint NOT NULL
    )
		
SET NOCOUNT ON

INSERT  @Table
        (Fund, FundID, Unit, Price, MktValue)
VALUES  ('ABC', 123, 1, 10, 10),
        ('ABC', 123, 1, 20, 20),
        ('ABC', 456, 1, 30, 30),
        ('DEF', 456, 1, 40, 40),
        ('DEF', 789, 1, 50, 50),
        ('XYZ', 789, 1, 60, 60),
        ('XYZ', 123, 1, 70, 70),
        ('XYZ', 456, 1, 80, 80);
        
WITH    MyCTE
          AS (SELECT    FundID,
                        SUM(Price) SubTotal
              FROM      @Table
              GROUP BY  FundID
             )
    SELECT  c1.FundID,
            c1.SubTotal,
            (c1.SubTotal * 100.0) / c2.Total
    FROM    MyCTE c1
            CROSS JOIN (SELECT  SUM(SubTotal) Total
                        FROM    MyCTE
                       ) c2

Open in new window


Output:
FundID      SubTotal      (No column name)
123      100      27.777777777777
456      150      41.666666666666
789      110      30.555555555555
0
 
LVL 25

Expert Comment

by:jogos
ID: 37771038
And when you want it to 2 decimals.

ROUND ( ((c1.SubTotal * 100.0) / c2.Total), 2 ) As pct
0
 

Author Closing Comment

by:tommym121
ID: 37772931
Thank you very much.
0

Featured Post

PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

SQL Server engine let you use a Windows account or a SQL Server account to connect to a SQL Server instance. This can be configured immediatly during the SQL Server installation or after in the Server Authentication section in the Server properties …
How to leverage one TLS certificate to encrypt Microsoft SQL traffic and Remote Desktop Services, versus creating multiple tickets for the same server.
Nobody understands Phishing better than an anti-spam company. That’s why we are providing Phishing Awareness Training to our customers. According to a report by Verizon, only 3% of targeted users report malicious emails to management. With compan…
The Email Laundry PDF encryption service allows companies to send confidential encrypted  emails to anybody. The PDF document can also contain attachments that are embedded in the encrypted PDF. The password is randomly generated by The Email Laundr…

856 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question