![]() |
Модераторы: LSD |
![]() ![]() ![]() |
|
Strucka |
|
|||
![]() Шустрый ![]() Профиль Группа: Участник Сообщений: 66 Регистрация: 27.5.2007 Репутация: нет Всего: нет |
Дано: приложение , которое периодически совершает выгрузку из БД и загрузку БД (СУБД явно не определено, в принципе вопрос относится к наиболее распространенным)
Задача: если пользователь выгрзузит одни и теже данные и затем приложение попытается их загрузить в скажем дочернюю БД, то insert пройдет 2жды? Ответ пока да дважды. Есть какой-нибудь механизм в СУБД, который можно было бы использовать при выгрузке данных, чтобы ситуации с повторным инсертом одних и тех же данных избежать? + тоже к базам данных просьба ознакомиться http://forum.vingrad.ru/forum/act-ST/f-13/...2/unread-1.html Это сообщение отредактировал(а) Strucka - 4.6.2008, 17:00 |
|||
|
||||
skyboy |
|
|||
неОпытный ![]() ![]() ![]() ![]() Профиль Группа: Модератор Сообщений: 9820 Регистрация: 18.5.2006 Где: Днепропетровск Репутация: 5 Всего: 260 |
да. есть такая вещь, как индексы. присуствует во всех популярных и большинстве используемых СУБД(естественно, со всеми возможными СУБД не знаком). индексы бывают уникальными(поддерживается большинством СУБД; с которыми работал - все поддерживали). индексы могут быть не на одно поле, а на набор полей.
Таким образом, если целевая СУБД поддерживает, создаешь уникальный индекс на набор полей, которые(как ни странно ![]() Однако, есть затык: реакция на попытку вставить дубликат уникального ключа может вызывать разную реакцию у разных СУБД: от игнорирования до генерации исключения и выдачи ошибки. Правда, СУБД может предоставлять возможность подавления исключения(наприер, в MySQL инструкция INSERT поддерживает опции. среди которых: IGNORE - игнорировать вставку при совпадении уникальных ключей; и ON DUPLICATE KEY UPDATE для реализации дополнительной логики при вставки записи с дубликатом уникального ключа) |
|||
|
||||
![]() ![]() ![]() |
Правила форума "Общие вопросы по базам данных" | |
|
Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:
Данный форум не предназначен для:
Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение.
Полезные советы: Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | СУБД, общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |