Misplaced Pages

Database refactoring

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.

This is an old revision of this page, as edited by Ed Poor (talk | contribs) at 22:13, 4 February 2011 (This quote could be the entire lede!). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

Revision as of 22:13, 4 February 2011 by Ed Poor (talk | contribs) (This quote could be the entire lede!)(diff) ← Previous revision | Latest revision (diff) | Newer revision → (diff)

A database refactoring is a simple change to a database schema that improves its design while retaining both its behavioral and informational semantics. A database refactoring is conceptually more difficult than a code refactoring; code refactorings only need to maintain behavioral semantics while database refactorings also must maintain informational semantics.

The process of database refactoring is the act of applying database refactorings to evolve an existing database schema (database refactoring is a core practice of evolutionary database design). You refactor a database schema for one of two reasons: to develop the schema in an evolutionary manner in parallel with the evolutionary design of the rest of your system or to fix design problems with an existing legacy database schema

Database refactoring does not change the way data is interpreted or used and does not fix bugs or add new functionality. Every single refactoring to a database leaves the system in a working state, thus not causing maintenance lags, provided the meaningful data exists in the production environment.

An example of database refactoring would be splitting an aggregate table into two different tables in the process of database normalization

Scott Ambler wrote:

  • A database refactoring is a small change to your database schema which improves its design without changing its semantics (e.g. you don't add anything nor do you break anything). The process of database refactoring is the evolutionary improvement of your database schema so as to improve your ability to support the new needs of your customers.

See also

Tools

References

  1. Scott Ambler and Pramod Sadalage (2006). Refactoring databases: Evolutionary database design. Addison-Wesley. ISBN 978-0321293534
This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.
Find sources: "Database refactoring" – news · newspapers · books · scholar · JSTOR (May 2009) (Learn how and when to remove this message)

External links

Category: