If this is your first visit, be sure to check out the FAQ by clicking the link above. You may have to register before you can post: click the register link above to proceed. To start viewing messages, select the forum that you want to visit from the selection below.

 
Go Back  dBforums > General > Database Concepts & Design > Normalization and dependencies

Reply
 
LinkBack Thread Tools Search this Thread Display Modes
  #1 (permalink)  
Old 03-12-06, 17:48
jjsobo05 jjsobo05 is offline
Registered User
 
Join Date: Mar 2006
Posts: 2
Normalization and dependencies

I am having some problems with database dependencies and was looking for some help. I just made up some data here to see if I am on the right track.

Stuff (H,I,J,K,L,M,N,O) Could someone tell me what normal form this would be if only H and I can act as the key

MORE_Stuff (D,O,B,G,C,J) Could someone tell me what normal form this would be if only Dand O can act as the key

Store_Item (Sku, PromoID,Vendor,Style,Price) Same with this one.

Software (softwarevendor,Product,release,systemreq,price,wa rranty) Is this first normal form and what would I have to do to put it into BCNF.

Thanks for the help I am having a few problems with dependencies and normalization, but I will hopefully get the hang of it.
Reply With Quote
  #2 (permalink)  
Old 03-12-06, 18:05
r937 r937 is online now
SQL Consultant
 
Join Date: Apr 2002
Location: Toronto, Canada
Posts: 19,524
if only H and I, or if only H or I? in any case, we can't tell, because we don't know what the dependencies of the other columns are on these two

for example, H could be order number, I could be order timestamp, and on the assumption that no two orders have exactly the same timestamp, either one of them could be the primary key, but if J is product number and K is product name, then K depends on J and not on the key

Store_Item looks like BCNF (although i am not sure, and i'm too lazy to look it up), with Sku, PromoID, and Vendor forming a 3-column composite primary key, and Style and Price depending on the key

same with Software, it looks like another 3-column composite key
__________________
r937.com | rudy.ca
please visit Simply SQL and buy my book
Reply With Quote
  #3 (permalink)  
Old 03-12-06, 18:09
jjsobo05 jjsobo05 is offline
Registered User
 
Join Date: Mar 2006
Posts: 2
Okay lets say these are the dependencies does that help.H,I, ---- J,K,l
J--- M
K---N
L---O

Thanks again for the help
Reply With Quote
  #4 (permalink)  
Old 03-12-06, 18:20
r937 r937 is online now
SQL Consultant
 
Join Date: Apr 2002
Location: Toronto, Canada
Posts: 19,524
that doesn't help me at all

sorry
__________________
r937.com | rudy.ca
please visit Simply SQL and buy my book
Reply With Quote
  #5 (permalink)  
Old 03-13-06, 02:14
Pat Phelan Pat Phelan is offline
Resident Curmudgeon
 
Join Date: Feb 2004
Location: In front of the computer
Posts: 12,605
They're apparently using Rutherford notation. To translate:

H, I, ----- J, K, M

means that the combination of attributes H and I imply a specific combination of attributes J, K, and M. In database terms, that makes the combination of H and I the primary key. Further translating:

J--- M
K---N
L---O

means that the presense of a value for J implies a value for M. Since J is a single attribute instead of a tuple set, this means that the presense of a value for J requires a presense of a value for M. SQL can do this via constraints, but it isn't pretty. A "real world" example of this would be that if a measurement for something is specified (for example a weight or length) as J, the presence of a unit (as M) is required. Early in the use, the contrapositive was assumed (no J enforced no M), however later in use that restriction was frequently ignored.

This notation was often used in Hierarchical Database implementations, but not often for relational implementations.

-PatP
Reply With Quote
  #6 (permalink)  
Old 03-13-06, 05:33
andrewst andrewst is offline
Moderator.
 
Join Date: Sep 2002
Location: UK
Posts: 5,171
Pat,

So are you saying that "J---M" does not mean that J functionally determines M, but that "H, I ----- J, K, M" does mean that (H, I) functionally determines (J, K, M)? That seems counter-intuitive.

I would have guessed that J---M does mean that J functionally determines M, and so "Stuff" violates 2NF and is therefore only in 1NF.
__________________
Tony Andrews
http://tinyurl.com/tonyandrews
Reply With Quote
  #7 (permalink)  
Old 03-13-06, 08:38
Pat Phelan Pat Phelan is offline
Resident Curmudgeon
 
Join Date: Feb 2004
Location: In front of the computer
Posts: 12,605
That weirdness of the notation kind of helps explain why relational folks aren't fond of it. The weirdness makes a lot more sense if you think in Hierarchical terms, where that actually makes sense (in its own, hierarchical way). It is also why I haven't seen Rutherford taught since the mid-to-late 1980s... It was a "blast from the past" to see the notation again.

-PatP
Reply With Quote
  #8 (permalink)  
Old 03-13-06, 09:15
andrewst andrewst is offline
Moderator.
 
Join Date: Sep 2002
Location: UK
Posts: 5,171
I'd never heard of "Rutherford notation", so I Googled it and got exactly one hit, which as you can see makes it all perfectly clear!
__________________
Tony Andrews
http://tinyurl.com/tonyandrews
Reply With Quote
Reply

Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is Off
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On