Skip to main content

Database Design Practices



In database discussions, it is common to hear the term normalization or database design come up. However,for the most parts these discussions revolve around splitting up the data that is stored between different tables to improve performance and to eliminate duplication.  This is extremely important and should be discussed in any discussion on tables but for the most part the discussions do not involve splitting up data between databases.  This is either assumed or just not put into practice as often as it should be.  Either way, it is important to consider when designing an application that will need to access data.





Information Commonality Data could be defined as the actual values that are stored in the database itself and are static until they are changed by some process (either manually or automated). Data by itself is useless if not processed in such a way as to give it meaning.  Information, on the other hand, is data processed in such a way as to give it meaning and is constantly changing based on the data stored.  In addition, the majority of data collected can be processed in multiple ways to provide multiple meaningful outputs.  In databases, many developers look at the data that is contained versus the information that the data is designed to provide.  Databases should be developed in such a way that each database produces a common set of information.  Tables that would hold data associated with human resource information should not be contained in the same database as tables that would contain parts for aircrafts in an airline database system.  If there is a need for the data in the inventory database to interact with data in the human resource database to provide the proper information, the MySQL server can pull data from the tables holding the data (even though they are in two different databases) to provide such information.  



Exclusive Data





In such situations where there are separate entities that utilize the same data structures, separating out the data may be the safest and most reliable way to ensure data integrity.  An example would be an accounting firm that is responsible for the payroll of two or three companies.  The application that would be created to support such as system could utilize the same data structures but have separate databases containing the actual data for each company.  This would eliminate any chance that data from one company could interact
with data from another company which would create an insecure and potentially precarious situation.  This would require time and energy put into ensuring that the database and its underlying components were solid enough to avoid the need for structural changes after implentation. Copying database structures from one database to another is an easy process in MySQL; however, any future changes would have to be done in the individual databases separately.





Comments

Popular posts from this blog

PHP INTRODUCTION

                     PHP  (recursive acronym for  PHP: Hypertext Preprocessor ) is a widely-used open source general-purpose scripting language that is especially suited for web development and can be embedded into HTML. PHP stands for  P HP:  H ypertext  P reprocessor PHP is a server-side scripting language, like ASP PHP scripts are executed on the server PHP supports many databases (MySQL, Informix, Oracle, Sybase, Solid, PostgreSQL, Generic ODBC, etc.) PHP is an open source software PHP is free to download and use Why PHP? PHP runs on different platforms (Windows, Linux, Unix, etc.) PHP is compatible with almost all servers used today (Apache, IIS, etc.) PHP is FREE to download from the official PHP resource:  www.php.net PHP is easy to learn and runs efficiently on the server side What can PHP do? Anything. PHP is mainly focused on server-side scripting, so you can...

Storage Engine Breakdown

The following diagram represents a simplified view of the MySQL server and its interaction with the  storage engines. The following properties are storage engine dependant: • Storage Medium – Each table uses its own method of storing the data it contains. • Transactional Capabilities – Certain storage engines handle transactional processing which ensures that integrity of a database is maintained during the processing of multiple SQL statements.

Outer Joins

Whereas an INNER JOIN will find combinations of matching rows from joined tables, the OUTER JOIN also finds the instances where a row in one table has no match in another table. An OUTER JOIN find matches (just like an INNER JOIN), but also identifies mismatches. Two forms of outer joins are LEFT JOIN and RIGHT JOIN . These do not use the comma separator or the INNER JOIN keywords. They each answer the same kinds of questions, but differ slightly in their syntax. That is a LEFT JOIN can always be re-written into a equivalent RIGHT JOIN. (In the following sections, the terms left table and right table refer to the tables named first and second in the FROM clause, respectively.)  Left Outer Join A left join is a type of outer join, written using the LEFT JOIN keywords. A left join treats the left table (the first one named) as a reference table and produces output for each row selected from it, whether or not the row is matched by rows in the right table. Like a join w...