Download presentation
Presentation is loading. Please wait.
Published byMoris Andrews Modified over 9 years ago
1
Database Design Process For many businesses, the database is the most important set of computer files they have. For some, like EBay or Facebook, the database IS the business. Having a database that is efficient and dependable is more important to the success of these businesses than any building, piece of equipment, or even person (except maybe the database administrator—the DBA!). Therefore, database design is an important, and reasonably well compensated, job. 1
2
Art or Science? I’ve read many books, articles, and web sites which discuss database design. There is no general consensus on how to design databases, but there are principles (3NF being the main one). Because of this, database design remains as much an art as a science. 2
3
Design Scenarios Often, the design approach depends on the starting point. Some examples: – Fixing an existing database which may be decades old, is extremely important to the company, and causes lots of problems because it violates 3NF. – Creating a relational database out of a collection of Excel files or other documents. This is common among small businesses when they start to grow—the burden of maintaining those Excel files becomes too large, and they decide they have to go to the professional approach. (Assignment 1 will approximate this approach.) – Creating a database from scratch, as you might for an Internet startup company. 3
4
Prerequisites “Databases Demystified” and similar texts include several chapters on the steps needed to design and implement databases. The most important step is to understand the business—how it operates now, and how they would like it to operate in the future. Therefore, professional database designers spend a lot of time examining existing data and related documents, and interviewing employees at various levels. 4
5
An Iterative Process Like computer programs, the only time a database design is really finished is when nobody is using it any more. The database both reflects and creates business rules; it makes doing some things very easy, and doing other things very difficult or impossible (which of course can be a good thing!). As the business grows and changes, the database will have to grow and change with it. 5
6
Getting it Done Nevertheless, at some point somebody has to start creating a database if there is ever going to be one. The books don’t agree on a single procedure, and of course any procedure will have to be adapted to whatever starting point you’ve been given. Nevertheless, having a basic approach in mind can be very helpful. Therefore, I’ll present a general approach which should help you to get started. 6
7
Step 1: Start with the Entities Once you have researched the business or other client for your database so that you have a reasonable idea of what’s going on, you can begin design. The first step is probably best done freeform--use a whiteboard or a sheet of paper to get started: – Start by identifying the entities that the database should track: Customers, Products, Sales, Suppliers, Contacts, Players, Teams, Airplanes, Airports, etc. – Then list attributes of these entities that need to be tracked. Don’t associate them directly with the entities at this point. 7
8
Step 2: Create Some Basic Tables In Access, create the beginnings of your table designs—one table per entity, with only the primary key fields in the tables for now. Select the primary keys by following the rules and procedures presented earlier. 8
9
Step 3: Sort Out the Relationships Determine the nature of the relationships between the entities (one-to-many, many-to- many). A relationship’s type is closely tied to how the business operates. For one-to-many relationships, add the appropriate foreign keys to the tables. For many-to-many relationships, create the intersection tables and create their primary keys out of the keys of the other two tables. 9
10
Step 4: Make the Relationship Diagram Show all of your tables in the relationship diagram. Create the appropriate foreign-key relationships, enforcing referential integrity. 10
11
Step 5: Put Attributes in the Proper Tables This is the step that you can practice using the “SecondNormalFormPractice” program. Every non-key attribute should be placed in the table in which it depends on the whole key and nothing but the key. 11
12
Step 6: Detailed Table Design See if any of your tables have several fields that do not apply to all of the records; if so, break that table into a super type table and related sub type tables. Make sure that every field is of the appropriate data type.
13
Step 7: Do Some Populating! The quickest way to start testing a database design is to put data into it. Access’s annoying error messages will guide you (sort of); most of them show up when you’re entering data, not during design. 13
14
Remember, It’s Iterative! At this point, designers often go back to step 1. Trying to put data into the database has helped them to discover entities, attributes and relationships they had left out the first time around. Don’t see it as a setback; it’s all a part of the process. If anything, just be less careful on the first one or two iterations—their main purpose isn’t to be the finished product, but rather to help you to understand the problem and how you are going to solve it. 14
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.