290 likes | 488 Views
Database refactoring. For the beginning…. Avoid overspecialization. Barrier. Application developer. Database developer. Communication Cooperation Exchange of experience. Developer. Developer. Definition.
E N D
For the beginning… • Avoid overspecialization Barrier Application developer Database developer CommunicationCooperationExchange of experience Developer Developer
Definition • Refactoring of databases is the database schema change, improving its design, but not affecting its behavioral and information semantics. • It contains both structural and functional aspects
What can we refactor in DB? DB keeps: • Data (are kept according to the scheme) • Stored code The stored code doesn’t differ from any other code (it should be tested) The scheme of data (tables, indexes, etc.) The availability of data complicates the refactoring of the scheme!
Why should we refactor? • Correct the inherited database • Ensure the evolutionary development • Prevent the redundant design (over-design)
Smells of bad code in database All the smells of codes can be applied to the stored code including: • Procedures-monsters • Spaghetti code • Code duplication • Oversaturation of the conditional operators • etc. Smells characteristic for DB: • Table/column of wide destination • Redundant data (repeated in several tables) • Table with a huge number of columns/rows • Smart columns (xml) • Lack of limitations (lack of validation) • Fear of changes in data scheme or procedure
Fear of changes • The most «stinking»smell • Prevents the development • Reduces the effectiveness • Suggests an even bigger mess • Over time it becomes only worse
How to proceed? • Create your sandbox of development • Transfer changes in the sandbox of integration • Introduce in production
Sandboxes Frequent deployment Controlled deployment Highly controlled deployment
Trivial things • Is it possible to rename a column in the database without changing the hundreds of applications? • If we can not make such a triviality as we can do something really serious?
Unit tests in the database • Is it too difficult? • Isn’t there a good testing tool (framework)?
Running unit tests • Anonymous PL/SQL code • No need to change the database • Call raise_application_error a specific communication in case of an error • A rollback at the end of the test • Launch any SQL tools
Logs changes (changelog) • You must track changes • Writing delta-scripts (migration): • At the beginning of the transition period • At the end of the transition period • The same scripts for • Update sandboxes • Deployment on the production
Teamwork • Developers • Close cooperation with DB administrators • Skills of operation with databases • Administrators of DB and designers of DB • Should be involved in developing the application • Skills of application development
Testing tools • Delta-scripts • Dbdeploy, liquibase, deltasql • It's easy to write yourself • PL/SQL code, Oracle SQL Devepoler, Intellij IDEA