Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / INSERT и UPDATE одним запросом / 4 сообщений из 4, страница 1 из 1
07.05.2007, 18:01
    #34510609
RussianSpy
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
INSERT и UPDATE одним запросом
Пишу статистику посещения ресурса (внутрисетевой ресурс) в зависимости от IP и даты.

Таблица примерно такая:
userip - int4
statdate - timestamp without time zone
hits - int4

При накрутке счетчиков приходится перед апдейтом выполнять селект - проверку на наличие записи для текущей даты.

Кусок процедуры:
Код: plaintext
1.
2.
3.
4.
5.
cnt = (SELECT COUNT(*) FROM daily_stat WHERE userip=IP AND statdate=CURRENT_DATE);
IF cnt< 1  THEN
  INSERT INTO daily_stat(userip, statdate) VALUES (IP, CURRENT_DATE);
END;
UPDATE hits=hits+ 1  WHERE userip=IP AND statdate=CURRENT_DATE;

Собственно вопрос: существует ли элегантный способ обойтись без проверочного селекта на наличие записи для текущей даты?

ЗЫ Также если есть в приведенном коде "некрасивости" - буду рад если меня ткнут в них носом. Заранее спасибо.
...
Рейтинг: 0 / 0
08.05.2007, 06:45
    #34511306
nma
nma
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
INSERT и UPDATE одним запросом
Можно так:
Код: plaintext
1.
2.
3.
UPDATE daily_stat set hits=hits+ 1  WHERE userip=IP AND statdate=CURRENT_DATE;
if not(found) then
  INSERT INTO daily_stat(userip, statdate) VALUES (IP, CURRENT_DATE);
end if;
...
Рейтинг: 0 / 0
08.05.2007, 10:12
    #34511545
LeXa NalBat
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
INSERT и UPDATE одним запросом
Присутствует в TODO. В 8.3 пока еще не будет.

http://www.postgresql.org/docs/faqs.TODO.html

Add REPLACE or UPSERT command that does UPDATE, or on failure, INSERT

To implement this cleanly requires that the table have a unique index so duplicate checking can be easily performed. It is possible to do it without a unique index if we require the user to LOCK the table before the MERGE.
...
Рейтинг: 0 / 0
28.09.2007, 11:03
    #34833753
PythonWin
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
INSERT и UPDATE одним запросом
nmaМожно так:
Код: plaintext
1.
2.
3.
UPDATE daily_stat set hits=hits+ 1  WHERE userip=IP AND statdate=CURRENT_DATE;
if not(found) then
  INSERT INTO daily_stat(userip, statdate) VALUES (IP, CURRENT_DATE);
end if;

это хранимая процедура? Если да то на каком языке - pl/pgsql ?
...
Рейтинг: 0 / 0
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / INSERT и UPDATE одним запросом / 4 сообщений из 4, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]