Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Составление SQL-запросов > Вставка уникальной записи


Автор: nIkTo 23.6.2010, 16:13
Необходимо вставить в таблицу запись соблюдая следующее условие :
Поле relative должно быть уникальным, а если запись с таким значением поля rating уже существует, то сравнить значения поля rating существующей записи с вставляемой записью и оставить в базе запись с меньшим значением поля rating.

таблица имеет следующую структуру :
Код

"id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL UNIQUE,
"relative" TEXT NOT NULL UNIQUE,
"keyword" TEXT NOT NULL,
"results" INTEGER,
"rating" INTEGER,
"language" CHAR(2)


Добавлено через 1 минуту и 42 секунды
Забыл написать, база : SQLite

Автор: skyboy 23.6.2010, 16:27
мне интересно: REPLACE вызывает триггеры ON UPDATE? если да, то вместо INSERT используй REPLACE. а в триггере на UPDATE пропиши сравнение старого и нового значения нужного поля, чтоб оставалось всегда меньшее значение. правда, при таком подходе возникает проблема: как можно увеличить значение в поле rating, чтоб не сработал триггер и не вернул старое значение? 
а вообще, пожалуй, было бы правильнее логику вынести за пределы запроса вставки. т.е. проверять на предмет существование, считывать значение rating существующей записи и уже на основании этого принимать решение: перезаписывать или оставлять предыдущую.

Автор: nIkTo 23.6.2010, 16:40
забыл дописать ещё один исход, если записи с таким значение поля не существует то необходимо просто вставить эту запись ..., так что как мне кажется REPLACE тут не совсем логично использовать ...

Автор: Akina 23.6.2010, 17:42
Два запроса.
Первый - безусловная вставка. Есть запись? плевать, просто проигнорим и сбросим ошибку (если она конечно duplicate primary key). 
Второй - безусловный апдейт (запись-то уже гарантированно есть!). Это та самая запись? наплевать, ничего же не изменится.

Автор: skyboy 23.6.2010, 23:28
Цитата(Akina @  23.6.2010,  16:42 Найти цитируемый пост)
Два запроса.

блин, точно!  smile 


Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)