Solved

Can I configure multiple surrogate keys on a table?

Posted on 2011-09-23
10
419 Views
Last Modified: 2016-02-14
I am working with a Time table and time intelligence in ssas 2008. I would like to assign  surrogate keys to FIscal Year Fiscal Quarter Fiscal Month Fiscal Day.  

Is there a way to perform this in column properties in the current table?
0
Comment
Question by:rhservan
[X]
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
  • 4
  • 4
  • 2
10 Comments
 
LVL 42

Accepted Solution

by:
dqmq earned 250 total points
ID: 36587862
I think you are misusing the term "surrogate keys".  "Surrogate keys" are assigned to tables, not to columns (FWIW, you can have as many as you want.  But what would be the point???) Also, surrogate keys are unique--if Fiscal Year were a surrogate key, then each year could only appear once in your table.  

Perhaps, do you mean "foreign key".  Not sure what you are trying to do?  

Or are you referring to the identity property?  Only one "identity" column is allowed per table.  

0
 
LVL 2

Assisted Solution

by:marappan
marappan earned 250 total points
ID: 36587946
Hi rhservan,

                      I can help you with this. But, I need to know why do you want to use surrogate key instead of using natural key. If you have already chosen a primary key can i know what is that? Also can you please explain what you are going to achieve by adding surrogate key?

Thanks,
Marappan
0
 
LVL 2

Expert Comment

by:marappan
ID: 36588015
If you are tying to enforce uniqueness to those four columns below is the syntax:

CREATE TABLE Calendar_DEMO
(
FIscal_Year INT NOT NULL UNIQUE,
Fiscal_Quarter INT NOT NULL UNIQUE,
Fiscal_Month INT NOT NULL UNIQUE,
Fiscal_Day INT NOT NULL UNIQUE
)
GO
0
Windows Server 2016: All you need to know

Learn about Hyper-V features that increase functionality and usability of Microsoft Windows Server 2016. Also, throughout this eBook, you’ll find some basic PowerShell examples that will help you leverage the scripts in your environments!

 

Author Comment

by:rhservan
ID: 36588023
I am building Fiscal YTD, QTD, MTD & DTD.  It was suggested that I use surrogate keys in order to utilize a cumulative total for each period.
0
 
LVL 2

Expert Comment

by:marappan
ID: 36588065
Can you please paste your scheme for better understanding?
0
 

Author Comment

by:rhservan
ID: 36588112
Schema attached.
SCHEMA.JPG
0
 
LVL 2

Expert Comment

by:marappan
ID: 36588467
Can you please give me the name of the table and column name you want to implement the key?
0
 

Author Comment

by:rhservan
ID: 36588528
DimTimeIn
Fiscal YTD, QTD, MTD & DTD
0
 

Author Comment

by:rhservan
ID: 36588694
I am preparing to run the time intelligence tool on my cube.

The DimTimeIn Table was created with two calendars:
1. Calendar Year
2. Fiscal Year

I have built hierarchies in SSAS for Fiscal Year. I would like for this calendar to provide:
1.F Year To Date - When clicked on the year value It gives me a cumulative total from January 1
2. F Quarter To Date - When clicked on the quarter value it gives me cumulative total from the first day of that quarter.
etc......

Hope this helps  
0
 
LVL 42

Expert Comment

by:dqmq
ID: 36589430
Let me comment on you DimTimeIn table.

1. It appears that it would be better named DimDate as the granularity is date, not time.  :>)

2. The table already has a surrogate key:  Date_Key.  To my way of thinking, PK_Date is also a surrogate key.  I'm still not quite "getting" the rationale for two surrogate keys on the same table.

3. The columns are present to do the rollups you desire.  I think what you are asking is there a way to combine the multi-column rollups into single-column rollups (for sake of simplicity, I guess).   Sure, you can do that.  

Let's say your FY column contains the 4-digit year and your FQ column contains the 1 digit quarter and your FM column contains the 1-2 digit month.  To do a rollup by month, you need to involve all 3 columns.  You can derive single columns: yyyyqq and yyyymm to enable single column rollups for FQ and FM.   You can even do it in a view or computed columns so that there is no effort to populate them and no chance they will get out of sync.  

4. Stiill not sure how "surrogate keys" apply to your situation.  The only "stretch" that comes to mind is if you are considering moving from a star design to a snowflake design. In that case FY, FQ, FM are dimensions in their own right and THOSE dim tables would best have surrogate keys that are referenced by foreign keys in the dimTimeIn table.

5.  I suppose I've confused you beyond hope, by now, so let me give the simple advice. Don't add anymore surrogate keys to dimTimeIn.  Do not add more foreign keys to the dimTimeIn table.  Either derive the new columns you need or if you need add FQ, FY dimensions and link them to your fact table.

 







 


 

0

Featured Post

Visualize your virtual and backup environments

Create well-organized and polished visualizations of your virtual and backup environments when planning VMware vSphere, Microsoft Hyper-V or Veeam deployments. It helps you to gain better visibility and valuable business insights.

Question has a verified solution.

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

Introduction SQL Server Integration Services can read XML files, that’s known by every BI developer.  (If you didn’t, don’t worry, I’m aiming this article at newcomers as well.) But how far can you go?  When does the XML Source component become …
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…
This video shows, step by step, how to configure Oracle Heterogeneous Services via the Generic Gateway Agent in order to make a connection from an Oracle session and access a remote SQL Server database table.
Via a live example, show how to shrink a transaction log file down to a reasonable size.

690 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