![]() |
Модераторы: skyboy |
![]() ![]() ![]() |
|
Parallelogram |
|
|||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 22.1.2013 Репутация: нет Всего: нет |
У меня есть таблица вида: NOMER COD. Нужно проверить, если телефон уже есть в базе, то обновить COD, если нет в базе, то создать запить телефон - код. У меня получается что-то подобное сделать с помощью циклов в php, но лучше бы сделать это одним запросом или с помощью триггера.
|
|||
|
||||
Parallelogram |
|
||||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 22.1.2013 Репутация: нет Всего: нет |
Единственное что я придумал, и конечно же не работает:
И такой не работает
Это сообщение отредактировал(а) Parallelogram - 10.10.2015, 07:12 |
||||
|
|||||
tzirechnoy |
|
|||
Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1173 Регистрация: 30.1.2009 Репутация: 3 Всего: 16 |
tel, разумеется, должэн обладать уникальным индэксом. |
|||
|
||||
Parallelogram |
|
||||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 22.1.2013 Репутация: нет Всего: нет |
А если я создам еще 1 столбец, например 'id' с ним такой фокус пойдет? Пусто он будет уникальным идентификатором. Просто tel может повторяться. P.s.: Не работает( Просто создает дубликат. Это сообщение отредактировал(а) Parallelogram - 10.10.2015, 15:57 |
||||
|
|||||
tzirechnoy |
|
|||
Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1173 Регистрация: 30.1.2009 Репутация: 3 Всего: 16 |
То есть оно у тебя не в первой нормальной форме? Поскольку в таблицэ только номер и код, номер можэт повторяться, код ты принудительно у всех записей с одним номером обновляешь при некоторых условиях. Ну, фигово тогда, чо. Сделай нормально пока не поздно. |
|||
|
||||
a0730 |
|
|||
Новичок Профиль Группа: Участник Сообщений: 0 Регистрация: 1.6.2008 Репутация: нет Всего: нет |
зачем хранить несколько одинаковых записей? Либо расскажи про задачу подробнее. Например, почему телефон может повторяться и какие значения принимает код в таких случаях. Этот ответ добавлен с нового Винграда - http://vingrad.com |
|||
|
||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
В MySQL есть для этого специальное INSERT ... ON DUPLICATE KEY UPDATE ..., обеспечивающее полный контроль за процессом, и его более простой аналог REPLACE - с минимальным функционалом. -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
tzirechnoy |
|
|||
Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1173 Регистрация: 30.1.2009 Репутация: 3 Всего: 16 |
При полном отсутствии UNIQUE это не поможэт ни капли. |
|||
|
||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Пусть добавит.
-------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
_zorn_ |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1077 Регистрация: 21.8.2007 Репутация: 2 Всего: 12 |
Не надо вводить людей в заблуждение. REPLACE это НЕ аналог ON DUPLICATE KEY UPDATE. REPLACE тупо удаляет запись перед вставкой если конфликт по ключу, ON DUPLICATE KEY UPDATE обновляет указанные поля. Чем чревато ? Например есть поле TIMESTAMP с дефолтным значением CURRENT_TIMESTAMP. Это поле никто не изменяет никогда, но какая нибудь логика на него завязана. При REPLACE оно всегда будет NOW()... |
|||
|
||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Вот было бы странно, если бы они были полными аналогами, верно? В основе своей они аналогичны, потому что выполняют одну и ту же операцию - вставку записи с контролем ненарушения условий уникальности, причём не нарушающая уникальная запись вставляется, а а нарушающая неуникальная обновляется. Всё остальное - детали, которые и составляют разницу, у одного оператора базой является существующая запись, а у другого вставляемая. И описанный сценарий - одно из следствий наличия этой разницы. Точно так же эти различия приведут и к иным несовпадающим последствиям - скажем, к тому, что по-разному на вторичное действие сработают триггеры, и пр. -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
_zorn_ |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Завсегдатай Сообщений: 1077 Регистрация: 21.8.2007 Репутация: 2 Всего: 12 |
Просто я разок споткнулся когда заюзал АНАЛОГ. Поэтому и говорю что нельзя СОВЕТОВАТЬ что REPLACE это аналог ON DUPLICATE KEY UPDATE
Он работает ПО ДРУГОМУ. В моем случае было АБСОЛЮТНО по другому. И если метод не работает ТАК ЖЕ то это НЕ аналог. Кстати про триггеры. На ON DELETE в теории должны срабатывать на REPLACE, но не проверял. |
|||
|
||||
Akina |
|
|||
Советчик ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 20581 Регистрация: 8.4.2004 Где: Зеленоград Репутация: 106 Всего: 454 |
Да никто с этим не спорит. Вот этим и отличаются "аналог" и "эквивалент". Но зачастую критичен итог, а не путь его достижения. Тебе просто не повезло - итог получался не тот.
Да. ON DUPLICATE KEY UPDATE - всегда срабатывает триггер ON INSERT, а при дублировании ещё и ON UPDATE. REPLACE - всегда срабатывает триггер ON INSERT, а при дублировании ещё и ON DELETE, после чего повторно срабатывает ON INSERT. -------------------- О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума. |
|||
|
||||
![]() ![]() ![]() |
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | MySQL | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |