Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Индексы
 
 автор: neadekvat   (14.09.2009 в 19:09)   письмо автору
 
 

Имеем два поля, оба должны быть уникальными (логин и мыло)
Если делать их уникальными по одному уже после создания таблицы, то, как я понял, создается два индекса и в каждом по одному полю.
Можно создать и один индекс, в котором будет два поля.

Но в чем разница?

  Ответить  
 
 автор: heed   (14.09.2009 в 19:56)   письмо автору
 
   для: 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 рядов

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования