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 do anything any other CGI program can do, such as collect form data, generate dynam

MySQL General Architecture

        MySQL operates in a networked environment using a client/server architecture. In other words, a central  program acts as a server, and various client programs connect to the server to make requests. A MySQL  installation has the following major components: MySQL Server, Client programs and MySQL non client  utilities.  MySQL Server MySQL Server, or mysqld, is the database server program. The server manages access to the actual  database (schema) on disk and in memory. MySQL Server is multi-threaded and supports many  simultaneous client connections. Clients can connect via several connection protocols. For managing  database contents, the MySQL server features a modular architecture that supports multiple storage engines  that handle different types of tables (for example, it supports both transactional and non-transactional  tables). Keep in mind the difference between a server and a host. The server is software (the MySQL server  program mysqld). Server characteristi