Mysql
 sql >> Base de données >  >> RDS >> Mysql

Données hiérarchiques d'exploitation MySQL

Ce que j'utilise est un design différent, et bien qu'il ait des limites, si vous pouvez les supporter, c'est très simple et très efficace.

Voici un exemple d'arbre taxonomique d'oiseaux dont la hiérarchie est Classe/Ordre/Famille/Genre/Espèce - l'espèce est le niveau le plus bas, 1 ligne =1 espèce :

CREATE TABLE `taxons` (
  `TaxonId` smallint(6) NOT NULL default '0',
  `ClassId` smallint(6) default NULL,
  `OrderId` smallint(6) default NULL,
  `FamilyId` smallint(6) default NULL,
  `GenusId` smallint(6) default NULL,
  `Name` varchar(150) NOT NULL default ''
);

et l'exemple des données :

+---------+---------+---------+----------+---------+-------------------------------+
| TaxonId | ClassId | OrderId | FamilyId | GenusId | Name                          |
+---------+---------+---------+----------+---------+-------------------------------+
|     254 |       0 |       0 |        0 |       0 | Aves                          |
|     255 |     254 |       0 |        0 |       0 | Gaviiformes                   |
|     256 |     254 |     255 |        0 |       0 | Gaviidae                      |
|     257 |     254 |     255 |      256 |       0 | Gavia                         |
|     258 |     254 |     255 |      256 |     257 | Gavia stellata                |
|     259 |     254 |     255 |      256 |     257 | Gavia arctica                 |
|     260 |     254 |     255 |      256 |     257 | Gavia immer                   |
|     261 |     254 |     255 |      256 |     257 | Gavia adamsii                 |
|     262 |     254 |       0 |        0 |       0 | Podicipediformes              |
|     263 |     254 |     262 |        0 |       0 | Podicipedidae                 |
|     264 |     254 |     262 |      263 |       0 | Tachybaptus                   |

C'est très bien car de cette façon vous accomplissez toutes les opérations nécessaires de manière très simple, tant que les catégories ne changent pas de niveau dans l'arborescence.