dbo Posted December 12, 2007 Share Posted December 12, 2007 I've got a weird situation and I'm drawing a blank on the exact term. I think that it's called disjointness constraint (an entity can be a member of at most one of the subclasses of the specialization). I'll explain the situation and you can tell me what it's called if that's not correct I think the easiest way to explain this is using an example. Assume that you have a generic EQUIPMENT table (parent). This just holds high level data on the equipment. A piece of equipment can be a BOAT (child), a CAR (child), or a TANK (child), but can never be more than one of these. This makes perfect sense in relational database theory... I'm unsure how to implement it in practice. Question 1 - What the heck is this constraint called? Question 2 - Is there a way to enforce this kind of relationship at the data model level or only via an application? Quote Link to comment https://forums.phpfreaks.com/topic/81358-solved-supertypesubtype-relationship-disjointness-constraint/ Share on other sites More sharing options...
dbo Posted December 12, 2007 Author Share Posted December 12, 2007 *bump* Any ideas? Quote Link to comment https://forums.phpfreaks.com/topic/81358-solved-supertypesubtype-relationship-disjointness-constraint/#findComment-413044 Share on other sites More sharing options...
fenway Posted December 12, 2007 Share Posted December 12, 2007 I've never constrained this type of relationship in the DB... Quote Link to comment https://forums.phpfreaks.com/topic/81358-solved-supertypesubtype-relationship-disjointness-constraint/#findComment-413144 Share on other sites More sharing options...
dbo Posted December 12, 2007 Author Share Posted December 12, 2007 I guess technically you could add a trigger to enforce it. It's one of those things in relational database theory that sounds good and makes sense... I've just never tried to put it into practice until now. I hate to have to rely on the application to maintain the data's integrity. I think it should be done at each level just like security. Quote Link to comment https://forums.phpfreaks.com/topic/81358-solved-supertypesubtype-relationship-disjointness-constraint/#findComment-413180 Share on other sites More sharing options...
fenway Posted December 13, 2007 Share Posted December 13, 2007 I agree, but this outside the rather outdated scope of RDBMS set theory. As long as your app controls the display, you can always run maintenance scripts to make sure nothing looks "funny". Sanity checks, basically. Quote Link to comment https://forums.phpfreaks.com/topic/81358-solved-supertypesubtype-relationship-disjointness-constraint/#findComment-413479 Share on other sites More sharing options...
dbo Posted December 13, 2007 Author Share Posted December 13, 2007 Thanks for the replies fenway. Quote Link to comment https://forums.phpfreaks.com/topic/81358-solved-supertypesubtype-relationship-disjointness-constraint/#findComment-413509 Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.