pixel-battle/database.sql

108 строки
2.9 KiB
PL/PgSQL

create table users (
id bigserial not null,
ip_address cidr not null,
created date default now()::date not null,
primary key (id),
unique (ip_address)
);
create table user_colors (
user_id bigint not null,
color integer not null,
primary key (user_id, color),
foreign key (user_id) references users
);
create table pixels (
x smallint not null,
y smallint not null,
color integer not null,
user_id bigint not null,
last_update timestamp default now() not null,
primary key (x, y),
foreign key (user_id) references users
);
create table history (
id bigserial not null,
user_id bigint not null,
time timestamp default now() not null,
primary key (id),
foreign key (user_id) references users
);
create table requests (
id bigserial not null,
ip_address cidr not null,
method text not null,
url text not null,
is_secure bool not null,
user_agent character varying (4096),
referer character varying (2048),
time timestamp default now() not null,
primary key (id)
);
create function pixels_history() returns trigger as $$
begin
insert into history (
user_id
) values (
new.user_id
);
return new;
end;
$$ language plpgsql;
create trigger pixels_history after insert or update on pixels
for each row execute procedure pixels_history();
create procedure put_pixel(
_x smallint,
_y smallint,
_color integer,
_ip_address cidr
) as $$
declare
_user_id bigint;
begin
insert into users (
ip_address
) values (
_ip_address
) on conflict (
ip_address
) do nothing;
_user_id = (
select
users.id
from
users
where
users.ip_address = _ip_address
);
insert into pixels (
x,
y,
color,
user_id,
last_update
) values (
_x,
_y,
_color,
_user_id,
default
)
on conflict (
x,
y
) do update set
color = excluded.color,
user_id = excluded.user_id,
last_update = excluded.last_update;
end;
$$ language plpgsql;
-- truncate pixels;