|  | 
|  | 1 | +CREATE EXTENSION snowflake; | 
|  | 2 | +CREATE SEQUENCE snowflake_seq USING snowflake; | 
|  | 3 | +SET snowflake.machine_id = 2000; -- error | 
|  | 4 | +ERROR:  2000 is outside the valid range for parameter "snowflake.machine_id" (0 .. 1023) | 
|  | 5 | +SET snowflake.machine_id = 4; -- ok | 
|  | 6 | +SELECT machine, counter FROM snowflake_get(nextval('snowflake_seq')); | 
|  | 7 | + machine | counter  | 
|  | 8 | +---------+--------- | 
|  | 9 | +       4 |       2 | 
|  | 10 | +(1 row) | 
|  | 11 | + | 
|  | 12 | +SELECT machine, counter FROM snowflake_get(lastval()); | 
|  | 13 | + machine | counter  | 
|  | 14 | +---------+--------- | 
|  | 15 | +       4 |       2 | 
|  | 16 | +(1 row) | 
|  | 17 | + | 
|  | 18 | +SELECT machine, counter FROM snowflake_get(nextval('snowflake_seq')); | 
|  | 19 | + machine | counter  | 
|  | 20 | +---------+--------- | 
|  | 21 | +       4 |       3 | 
|  | 22 | +(1 row) | 
|  | 23 | + | 
|  | 24 | +SELECT machine, counter FROM snowflake_get(currval('snowflake_seq')); | 
|  | 25 | + machine | counter  | 
|  | 26 | +---------+--------- | 
|  | 27 | +       4 |       3 | 
|  | 28 | +(1 row) | 
|  | 29 | + | 
|  | 30 | +-- Sequence relation exists, is unlogged and remains unlogged. | 
|  | 31 | +SELECT * FROM snowflake_seq; | 
|  | 32 | + count | is_called  | 
|  | 33 | +-------+----------- | 
|  | 34 | +     3 | t | 
|  | 35 | +(1 row) | 
|  | 36 | + | 
|  | 37 | +ALTER SEQUENCE snowflake_seq SET LOGGED; | 
|  | 38 | +SELECT relpersistence FROM pg_class where relname = 'snowflake_seq'; | 
|  | 39 | + relpersistence  | 
|  | 40 | +---------------- | 
|  | 41 | + u | 
|  | 42 | +(1 row) | 
|  | 43 | + | 
|  | 44 | +ALTER SEQUENCE snowflake_seq RESTART; | 
|  | 45 | +SELECT * FROM snowflake_seq; | 
|  | 46 | + count | is_called  | 
|  | 47 | +-------+----------- | 
|  | 48 | +     1 | f | 
|  | 49 | +(1 row) | 
|  | 50 | + | 
|  | 51 | +-- Identity column, where cache affects value. | 
|  | 52 | +SET default_sequence_access_method = 'snowflake'; | 
|  | 53 | +CREATE TABLE snowflake_tab (a int GENERATED ALWAYS AS IDENTITY, b int); | 
|  | 54 | +INSERT INTO snowflake_tab VALUES (DEFAULT, generate_series(1, 10)); | 
|  | 55 | +SELECT data.machine, data.counter | 
|  | 56 | +  FROM snowflake_tab, LATERAL snowflake_get(a) AS data; | 
|  | 57 | + machine | counter  | 
|  | 58 | +---------+--------- | 
|  | 59 | +       4 |       2 | 
|  | 60 | +       4 |       3 | 
|  | 61 | +       4 |       4 | 
|  | 62 | +       4 |       5 | 
|  | 63 | +       4 |       6 | 
|  | 64 | +       4 |       7 | 
|  | 65 | +       4 |       8 | 
|  | 66 | +       4 |       9 | 
|  | 67 | +       4 |      10 | 
|  | 68 | +       4 |      11 | 
|  | 69 | +(10 rows) | 
|  | 70 | + | 
|  | 71 | +DROP TABLE snowflake_tab; | 
|  | 72 | +DROP SEQUENCE snowflake_seq; | 
|  | 73 | +DROP EXTENSION snowflake; | 
0 commit comments