Mysql
 sql >> Datenbank >  >> RDS >> Mysql

MySQL-Design mit dynamischer Anzahl von Feldern

C) Verwenden Sie eine Normalform ; Verwenden Sie mehrere Zeilen mit entsprechenden Schlüsseln. ein Beispiel:

mysql> SELECT * FROM blah;
+----+-----+-----------+
| K  | grp | name      |
+----+-----+-----------+
|  1 |   1 | foo       |
|  2 |   1 | bar       |
|  3 |   2 | hydrogen  |
|  4 |   4 | dasher    |
|  5 |   2 | helium    |
|  6 |   2 | lithium   |
|  7 |   4 | dancer    |
|  8 |   3 | winken    |
|  9 |   4 | prancer   |
| 10 |   2 | beryllium |
| 11 |   1 | baz       |
| 12 |   3 | blinken   |
| 13 |   4 | vixen     |
| 14 |   1 | quux      |
| 15 |   4 | comet     |
| 16 |   2 | boron     |
| 17 |   4 | cupid     |
| 18 |   4 | donner    |
| 19 |   4 | blitzen   |
| 20 |   3 | nod       |
| 21 |   4 | rudolph   |
+----+-----+-----------+
21 rows in set (0.00 sec)

Dies ist die Tabelle, die ich in dieser anderen Frage zu group_concat . Sie werden feststellen, dass es einen eindeutigen Schlüssel K gibt für jede Reihe. Es gibt einen weiteren Schlüssel grp die jede Kategorie darstellt. Das verbleibende Feld stellt ein Kategoriemitglied dar, und es kann unterschiedliche Anzahlen davon pro Kategorie geben.