INSERT
e UPDATE
prestazioni varia poco: sarà quasi uguale per (INT)
e (INT, INT)
chiavi.
SELECT
prestazioni del composito PRIMARY KEY
dipende da molti fattori.
Se la tabella è InnoDB
, la tabella viene aggregata in modo implicito nel valore PRIMARY KEY
.
Ciò significa che la ricerca di entrambi i valori sarà più veloce se entrambi i valori comprendono la chiave: non sarà richiesta alcuna ricerca aggiuntiva di chiave.
Supponendo che la vostra richiesta è qualcosa di simile:
SELECT *
FROM mytable
WHERE col1 = @value1
AND col2 = @value2
e il layout della tabella è questa:
CREATE TABLE mytable (
col1 INT NOT NULL,
col2 INT NOT NULL,
data VARCHAR(200) NOT NULL,
PRIMARY KEY pk_mytable (col1, col2)
) ENGINE=InnoDB
, il motore avrà solo bisogno di ricercare il valore della chiave esatto nella tabella stessa.
Se si utilizza un campo autoincrement come un documento falso:
CREATE TABLE mytable (
id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
col1 INT NOT NULL,
col2 INT NOT NULL,
data VARCHAR(200) NOT NULL,
UNIQUE KEY ix_mytable_col1_col2 (col1, col2)
) ENGINE=InnoDB
, poi il motore avrà bisogno, in primo luogo, di ricercare i valori del (col1, col2)
nell'indice ix_mytable_col1_col2
, recuperare il puntatore di riga dall'indice (il valore di id
) e fare un'altra ricerca con id
nella tabella stessa.
Per le tabelle MyISAM
, tuttavia, questo non fa alcuna differenza, perché le tabelle MyISAM
sono organizzate in heap e il puntatore di riga è solo offset di file.
In entrambi i casi, verrà creato uno stesso indice (per PRIMARY KEY
o per UNIQUE KEY
) e verrà utilizzato allo stesso modo.
+1. Grazie, molto ben spiegato. – Fr0zenFyr