Maison > base de données > tutoriel mysql > Comment puis-je stocker des données similaires aux tableaux dans MySQL ?

Comment puis-je stocker des données similaires aux tableaux dans MySQL ?

Linda Hamilton
Libérer: 2024-12-29 15:00:19
original
297 Les gens l'ont consulté

How Can I Store Data Similar to Arrays in MySQL?

Stockage de tableaux dans MySQL

Dans MySQL, les tableaux en tant que types de données ne sont pas pris en charge. Cependant, il existe des approches alternatives pour gérer les données qui ressemblent à des tableaux.

Approche des tables et des JOINs

Une méthode consiste à créer plusieurs tables et à établir des relations entre elles à l'aide des JOIN. Considérons le schéma suivant :

CREATE TABLE person (
  id INT NOT NULL PRIMARY KEY,
  name VARCHAR(50)
);

CREATE TABLE fruits (
  fruit_name VARCHAR(20) PRIMARY KEY,
  color VARCHAR(20),
  price INT
);

CREATE TABLE person_fruit (
  person_id INT,
  fruit_name VARCHAR(20),
  PRIMARY KEY (person_id, fruit_name)
);
Copier après la connexion

Ici, la table person_fruit contient une ligne pour chaque fruit associé à une personne. Cette approche vous permet de stocker un nombre essentiellement illimité de fruits.

Exemple :

person_id fruit_name
1 banana
1 apple
1 orange

Requête :

SELECT p.*, f.*
FROM person p
INNER JOIN person_fruit pf
  ON pf.person_id = p.id
INNER JOIN fruits f
  ON f.fruit_name = pf.fruit_name;
Copier après la connexion

Cette requête renvoie tous les fruits associés à une personne.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal