postgresql/src/test/regress/expected/random.out

53 lines
1.2 KiB
Plaintext
Raw Normal View History

2000-01-06 07:40:54 +01:00
--
-- RANDOM
-- Test the random function
--
-- count the number of tuples originally, should be 1000
2000-01-06 07:40:54 +01:00
SELECT count(*) FROM onek;
count
-------
1000
(1 row)
-- pick three random rows, they shouldn't match
(SELECT unique1 AS random
FROM onek ORDER BY random() LIMIT 1)
INTERSECT
(SELECT unique1 AS random
FROM onek ORDER BY random() LIMIT 1)
INTERSECT
(SELECT unique1 AS random
FROM onek ORDER BY random() LIMIT 1);
random
--------
(0 rows)
-- count roughly 1/10 of the tuples
2000-01-06 07:40:54 +01:00
SELECT count(*) AS random INTO RANDOM_TBL
FROM onek WHERE random() < 1.0/10;
2000-01-06 07:40:54 +01:00
-- select again, the count should be different
INSERT INTO RANDOM_TBL (random)
SELECT count(*)
FROM onek WHERE random() < 1.0/10;
-- select again, the count should be different
INSERT INTO RANDOM_TBL (random)
SELECT count(*)
FROM onek WHERE random() < 1.0/10;
-- select again, the count should be different
INSERT INTO RANDOM_TBL (random)
SELECT count(*)
FROM onek WHERE random() < 1.0/10;
-- now test that they are different counts
2000-01-06 07:40:54 +01:00
SELECT random, count(random) FROM RANDOM_TBL
GROUP BY random HAVING count(random) > 3;
2000-01-06 07:40:54 +01:00
random | count
--------+-------
(0 rows)
SELECT AVG(random) FROM RANDOM_TBL
HAVING AVG(random) NOT BETWEEN 80 AND 120;
avg
-----
(0 rows)