Solved

Unique Count and Unique Count to Date (MDX)

Posted on 2004-04-23
6
616 Views
Last Modified: 2008-02-01
Hello, can anybody indicate the MDX to calculate Unique Count to date ?

Having two Periods

Period        Unique Count        Unique Count to Date
First            10                        10
Second        4                          Unique Count (First + Second)


So if 2 of the 4 items are contained in the first period, then the unique
count should be 10 + 2 = 12

Thanks in advance,
0
Comment
Question by:gflorez
  • 2
  • 2
6 Comments
 
LVL 4

Expert Comment

by:BulZeyE
ID: 10900660
are the periods signified by integers?  I need much more information.  Table structures, PK and FK please..
       
0
 

Author Comment

by:gflorez
ID: 10901021
This is just one large fact table and the date/period is defined as datetime type which is used to create a time dimension (year-week). Then I have an integer to find the unique occurences of an event within each week.


Date                            EventType
2/2/2003                       4
2/2/2003                       5
2/9/2003                       6                      
2/9/2003                       4
2/21/2003                     6                      


So going back to my question:

Date                     Count Unique for Period             Count Unique To Date
2/3/2003                    2                                                   2
2/9/2003                    2                                                   3
2/21/2003                  1                                                   3      

So for the week of 2/21/2003, the eventid # 6 was already counted for the week of 2/9/2003 so it should not be counted the next time it occurs.

Thanks


0
 

Author Comment

by:gflorez
ID: 10901325
Now, if it helps ... I can recreate the fact table from the following tables structure:

EventDesc                    Events

EventID                        EventID
EventStarts                  EventDate
Description                   EventLocation
                           

The PK is EventID, right now, there are many eventdates and I need to count only the first occurence in my cube.
0
 
LVL 4

Accepted Solution

by:
BulZeyE earned 500 total points
ID: 10902238
Try this:

create table table1 (datefield datetime, eventid int)

insert into table1
(datefield, eventid)
select
'2/2/2003',                      4
union all
select
'2/2/2003',                       5
union all
select
'2/9/2003',                       6                      
union all
select
'2/9/2003',                     4
union all
select
'2/21/2003',                     6    

select t2.datefield,
       t2.datecount,
       count(distinct t1.eventid)
  from table1 t1
 inner join (select datefield, count(distinct eventid) datecount
               from table1
              group by datefield) t2
  on t1.datefield <= t2.datefield
group by t2.datefield, t2.datecount
order by 1

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

Suggested Solutions

Title # Comments Views Activity
sql server query 18 42
SQL R 21 29
how to restore or keep sql2000  backups useful... 2 18
Casting is giving error in sql server 3 12
Ever needed a SQL 2008 Database replicated/mirrored/log shipped on another server but you can't take the downtime inflicted by initial snapshot or disconnect while T-logs are restored or mirror applied? You can use SQL Server Initialize from Backup…
I have a large data set and a SSIS package. How can I load this file in multi threading?
Via a live example, show how to extract insert data into a SQL Server database table using the Import/Export option and Bulk Insert.
Viewers will learn how to use the SELECT statement in SQL to return specific rows and columns, with various degrees of sorting and limits in place.

820 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