This is the 28th day of my participation in the August Text Challenge.More challenges in August

Preface: This article is my 28th article about MySQL, the level is general, ability is limited. The article is relatively shallow, suitable for novice.

1 overview

In the process of database design, we often use paradigm or anti-paradigm design patterns. Only by mastering the essentials of normal form and anti-normal form, and learning to mix them properly in practical development, can we design a database with reasonable structure and efficient execution.

2 features

Normal forms require that there be no transfer function dependencies in the data table, whereas anti-normal forms allow transfer function dependencies

3 the difference

  • Storage: Anti-paradigm has a lot of duplicate data, which takes up more memory. Normal tables are usually smaller, fit in memory, and perform operations faster.
  • Modification: Normal patterns are more flexible when it comes to modifying data, whereas anti-patterns modify the entire data and are error-prone.
  • Query: When querying records, the normal pattern often requires multiple table joins, while the anti-normal pattern can avoid association because all data is in one table. When there is a large amount of data, the efficiency of anti-normal pattern is obviously better.

4 instances

Here is a classic example of paradigms and antiparadigms:

Staff-department Table:

     

Department – Department Head Table:

     

Combining these two tables, we know that Tom and Hill are both working in Accounting in the department, and their leader is Alex. This design pattern is called a paradigm. The paradigm requires that there be no transfer function dependencies in the data table. We all know that there is a dependency of transfer function among employees, departments and leaders: employees — > departments — > leaders. But the design pattern of the paradigm separates this relationship so that the transitive relationship no longer exists in the data table.

Let’s take a look at the anti-paradigm design pattern. Since the anti-paradigm allows for transfer functions, it is possible to put all the data together in one table, as follows:

   

In this table, we can see that there are employee – > department – > leader transfer function dependencies in the table.