Error » Error News and Info » Knowledge Base » Basic database design question

Knowledge Base Most common error and how to trouble shoot them off

Post New Thread Reply
  Basic database design question
LinkBack Thread Tools Display Modes
Old 09-Feb-2007, 12:45 AM   #1 (permalink)
Administrator
 
Admin's Avatar

Posts: 875
Join Date: Oct 2005
Rep Power: 10 Admin has disabled reputation

IM:
Default Basic database design question

I have a table in Microsoft Access 2002 (though I don't believe my question is specific to Access) where the idea of a "one-to-many relationship" in two tables was smushed into that one table and the "many" part of was limited to 4 on. I suspect there is a name for this kind of table?

CONTRACTS: EMPLOYEE1, EMPLOYEE1_BONUS, EMPLOYEE2, EMPLOYEE2_BONUS, EMPLOYEE3, EMPLOYEE3_BONUS, EMPLOYEE4, EMPLOYEE4_BONUS,DATE-STUFF

The idea behind the table is that in a given contract, up to four employees can be involved, but "Fred" may be listed as EMPLOYEE1, EMPLOYEE2, etc. depending on the data-entry person.

Well, now I want to write an mssql query (in Access with access tables) to show me some things that seem tricky given the lack of a one-to-many relationship--specifically, I need to show how many contracts a given employee had throughout the year. But the employee's name is either EMPLOYEE1, EMPLOYEE2, EMPLOYEE3, OR EMPLOYEE4. Same problem with calculating how much bonus each one earned: four potential fields. So, should I restructure the database for a one-to-many relationship (the schema is simple enough to take a day or two), or am I overlooking some cool querying tricks?


solution:

Change that schema right away!



Seriously, you are seeing for yourself what that was a bad design, and you should get it changed ASAP. Before you know
it, someone will mention that they started using a fifth person on some jobs...

and

The person who designed the database had no idea what he was doing and missed the whole concept of Relational Databases.

Yes, redesign the database immediately to have at least 2 tables:

Employees and Contracts and there will be a PrimaryKey-ForeignKey relationship between Employees and Contracts
on EmployeeID. Contracts table will contain a PrimaryKey named ContractID and other contract information you want to store. Employees table will contain a PrimaryKey named EmployeeID and other employee information you want to store. If the bonus is on a contract basis it should be stored in the Contracts table, if not you can have another table for Bonuses which will contain EmployeeID, ContractID, Bonus and other bonus information you would like to store.

also

Right. You need to make a new table that lists each employee and bonus as an individual record. Suppose you call the new table EmpBonus. I will also assume that employees and contracts are uniquely identified by integers.

CREATE TABLE EmpBonus (
ContractID INTEGER UNSIGNED NOT NULL DEFAULT 0,
EmployeeID INTEGER UNSIGNED NOT NULL DEFAULT 0,
Bonus DECIMAL,
PRIMARY KEY(ContractID, EmployeeID)
)

Then, you can

SELECT ContractID, EMPLOYEE1, EMPLOYEE1_BONUS
INTO EmpBonus
FROM CONTRACTS WHERE NOT EMPLOYEE1 IS NULL;

Then repeat for EMPLOYEE[2-4]

Then you can do the queries that you want to, like

SELECT Bonus from EmpBonus WHERE EmployeeID='xxxxx';

OF course, if there is other contract information (i.e. client, address, etc), you would have another table with ContractID as the primary key and you would store that data there.
Admin is offline  
Digg this Post!Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Reply With Quote
   


   
Post New Thread Reply


Currently Active Users Viewing This Thread: 1 (0 members and 1 guests)
 
Thread Tools
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 On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On
Forum Jump


All times are GMT -8. The time now is 09:02 PM.

Powered by vBulletin® Version 3.7.2
Copyright ©2000 - 2008, Jelsoft Enterprises Ltd.
Search Engine Friendly URLs by vBSEO 3.2.0

DMCA Policy

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227