Ovde se radi o linearnoj funkciji f(x) = a * x + b, f(0) = 381111333, f(1) = 381666999
Lako se dolazi da je to funkcija
y = (381666999 - 381111333) * x - 381111333
odnosno
y = (381666999 - 381111333) * random() - 381111333
pretvoreno u integere
y = trunc((381666999 - 381111333) * random() - 381111333)
Rezultat izvršenja random() funkcije je broj iz poluotvoreni interval [0 .. 1). To znači da gornja funkcija nikada ne bi vratila 381666999 kao rezultat. Zbog toga je prava funkcija dobijena povećavanjem onog 'a' parametra za 1 pa se na kraju dobija
y = trunc((381666999 - 381111333 + 1) * random() - 381111333)
Parametrizovano i pretvoreno u plpgsql dobijamo
Code:
CREATE OR REPLACE FUNCTION brtel (p_min bigint, p_max bigint) RETURNS bigint AS
$body$
BEGIN
RETURN trunc((p_max-p_min+1) * random() + p_min);
END;
$body$
LANGUAGE 'plpgsql' IMMUTABLE CALLED ON NULL INPUT SECURITY INVOKER;
Funkcija se upotrebljava sa
Code:
SELECT brtel(381111333, 381666999)
"The best code is no code at all."
- Zidar (ES član)
"Biggest obstacle to learning
SQL is unlearning procedural
programming." - Joe
Celko
"Minimize code, maximize data."
- A. Neil Pappalardo