Производительность
INSERT
и UPDATE
мало меняется: она будет практически одинаковой для клавиш (INT)
и (INT, INT)
.
SELECT
производительность композита PRIMARY KEY
зависит от многих факторов.
Если ваша таблица InnoDB
, то таблица неявно сгруппирована по значению PRIMARY KEY
.
Это означает, что поиск обоих значений будет быстрее, если оба значения составляют ключ: никакого дополнительного поиска ключа не потребуется.
Предположим, ваш запрос выглядит примерно так:
SELECT *
FROM mytable
WHERE col1 = @value1
AND col2 = @value2
и раскладка таблицы такая:
CREATE TABLE mytable (
col1 INT NOT NULL,
col2 INT NOT NULL,
data VARCHAR(200) NOT NULL,
PRIMARY KEY pk_mytable (col1, col2)
) ENGINE=InnoDB
, движку просто нужно найти точное значение ключа в самой таблице.
Если вы используете поле автоинкремента в качестве поддельного идентификатора:
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
, тогда движку потребуется сначала найти значения (col1, col2)
в индексе ix_mytable_col1_col2
, извлечь указатель строки из индекса (значение id
) и выполнить другой поиск по id
в самой таблице.
Для таблиц MyISAM
, однако, это не имеет значения, поскольку таблицы MyISAM
организованы в виде кучи, а указатель строки - просто смещение файла.
В обоих случаях будет создан один и тот же индекс (для PRIMARY KEY
или для UNIQUE KEY
) и будет использоваться одинаково.