|
|
|
| Имеем два поля, оба должны быть уникальными (логин и мыло)
Если делать их уникальными по одному уже после создания таблицы, то, как я понял, создается два индекса и в каждом по одному полю.
Можно создать и один индекс, в котором будет два поля.
Но в чем разница? | |
|
|
|
|
|
|
|
для: neadekvat
(14.09.2009 в 19:09)
| | при составном уникальном ключе проверяется уникальность только двух значений . как одного.
CREATE TABLE IF NOT EXISTS `dir` (
`id` INT AUTO_INCREMENT,
`nik` varchar(32) NOT NULL,
`addr` varchar(300) NOT NULL,
PRIMARY KEY (id),
UNIQUE KEY nikaddr (nik, addr)
) ENGINE=MyISAM ;
INSERT INTO dir (nik, addr)
VALUES
('john','john@doe.com'),
('john','john@doe.ru'),
('john','jennie@doe.com'),
('john','jennie@doe.ru'),
('jennie','jennie@doe.com'),
('jennie','jennie@doe.ru'),
('jennie','john@doe.com'),
('jennie','john@doe.ru');
SELECT * FROM dir;
DROP TABLE `dir`;
при всего двух именах и четырёх адресах можно вставить 8 рядов | |
|
|
|