In this PostgreSQL post explains how to use the PostgreSQL setseed function with syntax and examples.
The PostgreSQL setseed function can be used to set a seed for the next time that you call the random function. If you do not call setseed, PostgreSQL will use its own seed value. This may or may not be truly random.
If you set the seed by calling the setseed function, then the random function will return a repeatable sequence of random numbers that is derived from the seed.
The syntax for the setseed function in PostgreSQL is:
A value between 1.0 and -1.0, inclusive, that is used to provide the seed for the next call to the random function.
The setseed function can be used in the following versions of PostgreSQL:
Let's explore how to use the setseed function in PostgreSQL to seed the random function.
If you do not call the setseed function before the random function, PostgreSQL will provide its own seed. This value will not be known to you.
For example:
Each time you execute the random function, you will get a new random number. Your random numbers returned will differ from our example above because your seed will be different from ours.
Now, let's look at what happens when we use the setseed function before calling the random function.
For example, let's set the seed to 0.5 and then call the random function 3 times:
In this example, we call setseed once followed by the random function 3 times. By doing this, we get predictable random numbers. With a seed of 0.5, you will always get 0.798512778244913 as the first random number, 0.518533017486334 as the second random number, and 0.0734698106534779 as the third random number.
Sometimes it is desirable to never have predictable results. This can be achieved by calling setseed with different values in between calls to the random function.
For example:
By calling setseed between calls to the random function, the random numbers will not be predictable.