Powinieneś zaimplementować trzy tabele:
CREATE TABLE customer (
customer_id int - Autoincrement,
customer_name varchar(100)
)
CREATE TABLE icecream (
icecream_id int - Autoincrement,
flavor varchar(100)
)
CREATE TABLE cust_flavors (
customer_id int,
icecream_id int,
preference int
)
cust_flavors
tabela zawiera wszystkie wybory dokonywane przez każdego klienta. Aby wyświetlić listę wyborów klienta, użyj:
SELECT c.customer_name, i.flavor, cf.preference
FROM customer c LEFT JOIN cust_flavors cf
ON c.customer_id = cf.customer_id
LEFT JOIN icecream i
ON cf.icecream_id = i.icecream_id
WHERE c.customer_id = @customer
ORDER BY cf.preference
preference
Kolumna byłaby używana, jeśli istnieje priorytet do przypisania smakom. Oznacza to, że klient lubi wanilię bardziej niż jagodę (jeśli to ważne).