Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / FUNCTION & UPDATE / 2 сообщений из 2, страница 1 из 1
10.10.2006, 10:54
    #34043542
amman
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
FUNCTION & UPDATE
Добрый день,

FreeBSD 6.1 + Postgresql 8.1.3

Есть табличка 'gateways' содержащая имена устройств, и их приоритеты. Необходимо изменять данные приоритеты после/при каждой выборки, т.е. SELECT, приоритеты необходимы чтобы выбирать записи в порядке "карусели". Если вызывать отдельно запрос UPDATE то все прекрасно меняется, если же запрос находится в теле функции, то не происходит смены приоритетов.

Подскажите пожалуйста в чем может быть проблемы?


CREATE TABLE gateways (
id bigserial not null,
name varchar(64) NOT NULL DEFAULT ''::character varying,
priority int4 DEFAULT 0,
CONSTRAINT gateways_pkey PRIMARY KEY (id)
);

INSERT INTO gateways (name, priority) VALUES('gw1', 0);
INSERT INTO gateways (name, priority) VALUES('gw2', 1);


CREATE OR REPLACE FUNCTION getanswer(gw varchar)
RETURNS text AS $$
DECLARE
BEGIN
update gateways set priority = mod((priority + 1), (select count(*) from gateways));

return gw;

END;
$$
LANGUAGE 'plpgsql';

SELECT getanswer(name) FROM gateways;
...
Рейтинг: 0 / 0
10.10.2006, 11:50
    #34043795
LeXa NalBat
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
FUNCTION & UPDATE
SELECT getanswer(name) FROM gateways;

при этом функци вызывается два раза, так как в gateways две строки, и меняет приоритеты дважды приводя их к исходному состоянию.

Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
CREATE TABLE gateways (
id bigserial not null,
name varchar( 64 ) NOT NULL DEFAULT ''::character varying,
priority int4 DEFAULT  0 ,
CONSTRAINT gateways_pkey PRIMARY KEY (id)
);

CREATE OR REPLACE FUNCTION switch_priorities()
RETURNS integer AS $$
BEGIN
update gateways set priority = mod((priority +  1 ), (select count(*) from gateways));
return  1 ;
END;
$$
LANGUAGE 'plpgsql';

INSERT INTO gateways (name, priority) VALUES('gw1',  0 );
INSERT INTO gateways (name, priority) VALUES('gw2',  1 );

SELECT * from gateways;

SELECT switch_priorities();

SELECT * from gateways;

drop table gateways;
drop function switch_priorities();
...
Рейтинг: 0 / 0
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / FUNCTION & UPDATE / 2 сообщений из 2, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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