You can instantly copy 1TB+ datasets via Neon branches, e.g. for ephemeral environments - Learn how they compare to other "branching" features

PostgreSQL RANDOM() Function

Summary: in this tutorial, you will learn how to use the PostgreSQL RANDOM() function to generate random values.

Introduction to the PostgreSQL RANDOM() function

The RANDOM() function allows you to generate random values. Here’s the basic syntax of the RANDOM() function:

RANDOM()

The RANDOM() function returns a random value between 0 and 1.

In practice, you’ll find the RANDOM() function useful in various applications such as:

  • Generate random data.
  • Shuffling results.
  • Select random rows from a table.

PostgreSQL RANDOM() function examples

Let’s take some examples of using the PostgreSQL RANDOM function.

1) Basic PostgreSQL RANDOM() function example

The following query uses the RANDOM() function to generate a random value between 0 and 1:

SELECT RANDOM() AS random;

Output:

random
--------------------
 0.1118658328429385
(1 row)

2) Generating random integers

To generate a random integer, you need to use the RANDOM() function with the FLOOR() function. For example, the following generates a random integer between 1 and 100:

SELECT floor(random() * 100) + 1 AS random_integer;

Sample output:

random_integer
----------------
             34
(1 row)

3) Retrieving random records

Sometimes, you may need to retrieve random records from a table. To do that, you can utilize the RANDOM() function in conjunction with the ORDER BY clause.

For example, the following query uses the RANDOM() function to retrieve a random film from the film table in the sample database:

SELECT title
FROM film
ORDER BY RANDOM()
LIMIT 1;

Sample output:

title
-------------------
 Outfield Massacre
(1 row)

4) Shuffling results

You can use the RANDOM() function to shuffle the rows in a result set of a query.

For example, the following query uses the RANDOM() function to shuffle the rows from the film table:

SELECT title FROM film ORDER BY RANDOM();

Sample output:

title
-----------------------------
 Shootist Superfly
 Beauty Grease
 Craft Outfield
 Amistad Midsummer
 Lord Arizona
...

5) Seed for reproducibility

By default, PostgreSQL uses a deterministic pseudo-random number generator to generate random numbers.

But if you need to generate the same random number, you can reissue the SETSEED() function in the same session with the same argument.

For example, the following query always returns the same random number:

SELECT SETSEED(0.5), RANDOM();

Summary

  • Use the RANDOM() function to generate a random number between 0 and 1.

Last updated on

Was this page helpful?