Management of the Evolution of Database-Centric Information Systems Panos Vassiliadis 2, George Papastefanatos 1, Timos Sellis 1, Yannis Vassiliou 1 1 National Technical University of Athens-KDBMS Laboratory 2 University of Ioannina
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Database Schema Evolution Current database systems are continuously evolving environments, where design constructs are Added Removed Modified Evolution is not handled by current DBMS with an automatic way E.g., syntactic as well as semantic adaptation of queries and views: time-consuming task, treated in most of the cases manually Evolution driven database design is missing
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Empirical Studies on Database Schema Evolution Principled Response to evolutionary events Design Patterns Principled Description of the architecture of a database-centric Information System Metrics Evolving Database Systems Issues in Database Schema Evolution
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Empirical Studies on Database Schema Evolution Collect test cases to come up with fundamental laws that govern database evolution Establish an experimental protocol for monitoring existing real-world databases and discover the way they evolve Collect such results and make them available to the research community Empirical Studies on Database Schema Evolution Principled Response to evolutionary events Design Patterns Principled Description of the architecture of a database- centric Information System Metrics Evolving Database Systems
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Principled Description of the architecture of a database-centric Information System A commonly agreed formalism to express the internals of a database-centric system a model of the structural properties and dynamics of database- centric systems interdependencies in the components of a complex database- centric system a scientific foundation for the architecture of complex database -centric systems Empirical Studies on Database Schema Evolution Principled Response to evolutionary events Design Patterns Principled Description of the architecture of a database- centric Information System Metrics Evolving Database Systems
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Principled Response to evolutionary events Forecast the impact of an evolution event Handle conflicts Keep versions of the database consistent to user views Treat evolution in the presence or absence of user requirements Automation of the reaction to changes self-monitoring impact prediction auto-regulation self-repairing Empirical Studies on Database Schema Evolution Principled Response to evolutionary events Design Patterns Principled Description of the architecture of a database- centric Information System Metrics Evolving Database Systems
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Metrics Measures for the quality of the design of a database wrt its evolution “Right” families of such measures Empirical Studies on Database Schema Evolution Principled Response to evolutionary events Design Patterns Principled Description of the architecture of a database- centric Information System Metrics Evolving Database Systems
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Design Patterns Come up with a well-founded theory for design patterns wrt evolution Eliminate maintenance traps due to ad-hoc, or complex solutions Methods for testing database designs Empirical Studies on Database Schema Evolution Principled Response to evolutionary events Design Patterns Principled Description of the architecture of a database- centric Information System Metrics Evolving Database Systems
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Database Schema Evolution – Our approach Mechanism for performing what-if analysis for potential changes of database configurations Evolving databases Queries Database Schema Graph-based modeling for uniform representation Rules for Handling Evolution Metrics for Evaluating Evolution Design Evolving applications Graph based representation of database constructs (i.e., relations, views, constraints, queries) Annotation of graph with rules for adapting queries to database schema evolution
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Graph based representation Q:SELECT EMP.Emp#, Sum(WORKS.Hours) as T_Hours FROM EMP, WORKS WHERE EMP.Emp# = WORKS.Emp# GROUP BY EMP.Emp#
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Annotation of graph with rules for adapting queries to database schema evolution Set of evolving database constructs: relations attributes constraints Set of potential evolution changes: addition deletion modification Set of reaction policies: propagate block prompt According to prevailing policy, the proper action is taken graph transformation
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, An Example Annotated Query Graph Event Add attribute Phone to EMP relation Transformed Query Graph
P.Vassiliadis, G.Papastefanatos, T.Sellis, Y. Vassiliou. Management of the Evolution of Database-Centric Information Systems PresDB ’07, Edinburgh, Conclusions – Future Work A tool for visualizing and performing what-if analysis for several evolution scenarios. SQL extensions for annotating graph constructs with evolution semantics Evolution-driven database design Design patterns for allowing smooth evolution Definition of graph based metrics evaluating the system design