![]() |
Модераторы: skyboy |
![]() ![]() ![]() |
|
Ripper |
|
|||
![]() Lonely soul... ![]() ![]() Профиль Группа: Участник Сообщений: 920 Регистрация: 30.6.2004 Где: г. Москва Репутация: нет Всего: 23 |
Здравствуйте.
У меня есть таблица предложений контрактов, где есть такие поля: ID, proposer, target, contract_type, date. Как грамотнее написать запрос на добавление строки в таблицу, чтобы пара proposer, target оказалась уникальной? Т.е. если такие два значения уже существуют, то не добавлять запись? На ум приходит написать что-то вроде insert into contract_suggestion (proposer, target, contract_type, date) values (...) where not exists (select * from contract_suggestion where (proposer={$proposer} and target={$target}) или как-то так. А, и еще пара должна быть уникальна с обоих сторон, т.е. не должно быть скажем двух пар: 2,5 и 5,2. Но я думаю есть более хорошее решение. Спасибо заранее. -------------------- "Он знает: надо смеяться над тем, что тебя мучит, иначе не сохранишь равновесия, иначе мир сведет тебя с ума" - Над кукушкиным гнездом |
|||
|
||||
Zloxa |
|
|||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
Добавить ограничение уникальности (unique constraint) по паре (proposer, target).
Другие способы обеспечения уникальности - от лукавого. -------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
|||
|
||||
Ripper |
|
|||
![]() Lonely soul... ![]() ![]() Профиль Группа: Участник Сообщений: 920 Регистрация: 30.6.2004 Где: г. Москва Репутация: нет Всего: 23 |
Да, а вот если в случае что пара должна быть уникальна в обоих комбинациях? Например если есть 5,3 то 3,5 уже не должно быть?
В интернете нашел пример с триггером, вроде помогло) -------------------- "Он знает: надо смеяться над тем, что тебя мучит, иначе не сохранишь равновесия, иначе мир сведет тебя с ума" - Над кукушкиным гнездом |
|||
|
||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Ввести constraint на уникальность CONCAT(MIN(proposer, target), MAX(proposer, target)) -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
Zloxa |
|
|||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
Akina, маська умеет строить ключи по функции?
![]() Крайне рекомендую внимательно протестировать работу этого триггера в многопользовательском режиме, в разных режимах изоляции транзакций. ![]() -------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
|||
|
||||
Akina |
|
||||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Нет. Но, как всегда, есть путь через задний проход... Вводится доп. поле. На него накладывается ограничение уникальности. Поле напрямую нигде не используется, заполняется или изменяется в триггере. При нарушении уникальности срабатывает ограничение, и отваливается весь запрос.
В примере val2 - как раз такое поле, заполняемое из триггера неявно. Наложите на него UNIQUE - и при дублировании вставка строк обломится.
Аналогично создаётся и триггер before update. Поскольку мы работаем исключительно с таблицей NEW - нам не страшны никакие многопользовательские заморочки. Или, вернее, так - мы не получим никаких ДОПОЛНИТЕЛЬНЫХ граблей. Это сообщение отредактировал(а) Akina - 19.12.2011, 09:15 -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
||||
|
|||||
Zloxa |
|
|||
![]() Чо? ![]() ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 3473 Регистрация: 12.9.2008 Репутация: 33 Всего: 161 |
Я спросил никак не потому, что хотел там подколоть или что-то вроде, но потому, что оракл умеет. Плюс и оракл и ms поддерживают вычисляемые столбцы, на которые тоже можно накладывать ограничения. Да, при такой реализации все должно быть нормуль. Ограничение контролируется уникальным ключом. Я предостережение оставлял на случай, если ТС замутил реализацию контроля уникальности не ключом а триггером. Типа выбирается из таблы по значению ключа и поднимает исключение, если нашел задвоения. -------------------- Достоверно известно, что 89% людей доверяют статистике взятой с потолка ![]() |
|||
|
||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Я знаю. -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
![]() ![]() ![]() |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | MySQL | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |