mirror of
https://github.com/timescale/timescaledb.git
synced 2025-05-28 09:46:44 +08:00
The numeric format changed between PG13 and PG14 to include infinities. As a result the serialized partial state of numeric aggregates also changed format. If a user that has stored partials (e.g. by using Continuous Aggregates) upgrades to PG14 then the partial state deserialization will lead to errors due to the mismatch with the PG14 code. Repair the deserialization process on the fly by appending zeroed plus-infinity and minus-infinity counts for the numeric aggregate state to use. Fixes #4427
3.9 KiB
3.9 KiB
1 | a | b | partialb | partialc | partiald | partiale | partialf |
---|---|---|---|---|---|---|---|
2 | 1 | 10 | \x00000000000000010001000000000000000a0000000000000000000000010000000000000000 | \x68656c6c6f | \x00011f1c121ac400 | \x00000000000000010001000000000000000a000100000000000000640000000000000000000000010000000000000000 | \x00000000000000010001000000000000000a000100000000000000640000000000000000000000010000000000000000 |
3 | 2 | 10 | \x00000000000000010001000000000000000a0000000000000000000000010000000000000000 | \x68656c6c6f | \x00011f1c121ac400 | \x00000000000000010001000000000000000a000100000000000000640000000000000000000000010000000000000000 | \x00000000000000010001000000000000000a000100000000000000640000000000000000000000010000000000000000 |
4 | 1 | 30 | \x00000000000000010001000000000000001e0000000000000000000000010000000000000000 | \x61626364 | \x00011f444dc98400 | \x00000000000000010001000000000000001e000100000000000003840000000000000000000000010000000000000000 | \x00000000000000010001000000000000001e000100000000000003840000000000000000000000010000000000000000 |
5 | 12 | \x000000000000000000000000000000000000000000000000000000000000000000000000 | \x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 | \x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 | |||
6 | 1 | 40 | \x0000000000000001000100000000000000280000000000000000000000010000000000000000 | \x6162636465 | \x000000000000000100010000000000000028000100000000000006400000000000000000000000010000000000000000 | \x000000000000000100010000000000000028000100000000000006400000000000000000000000010000000000000000 | |
7 | 1 | 50 | \x0000000000000001000100000000000000320000000000000000000000010000000000000000 | \x00011f1c121ac400 | \x000000000000000100010000000000000032000100000000000009c40000000000000000000000010000000000000000 | \x000000000000000100010000000000000032000100000000000009c40000000000000000000000010000000000000000 | |
8 | 11 | \x000000000000000000000000000000000000000000000000000000000000000000000000 | \x68656c6c6f | \x00011f2dac373800 | \x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 | \x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 | |
9 | 2 | 20 | \x0000000000000001000100000000000000140000000000000000000000010000000000000000 | \x68656c6c6f | \x00011f1c121ac400 | \x000000000000000100010000000000000014000100000000000001900000000000000000000000010000000000000000 | \x000000000000000100010000000000000014000100000000000001900000000000000000000000010000000000000000 |
10 | 3 | 40 | \x0000000000000001000100000000000000280000000000000000000000010000000000000000 | \x000000000000000100010000000000000028000100000000000006400000000000000000000000010000000000000000 | \x000000000000000100010000000000000028000100000000000006400000000000000000000000010000000000000000 | ||
11 | 3 | 50 | \x0000000000000001000100000000000000320000000000000000000000010000000000000000 | \x000000000000000100010000000000000032000100000000000009c40000000000000000000000010000000000000000 | \x000000000000000100010000000000000032000100000000000009c40000000000000000000000010000000000000000 | ||
12 | 2 | 30 | \x00000000000000010001000000000000001e0000000000000000000000010000000000000000 | \x68656c6c6f | \x00011f1c121ac400 | \x00000000000000010001000000000000001e000100000000000003840000000000000000000000010000000000000000 | \x00000000000000010001000000000000001e000100000000000003840000000000000000000000010000000000000000 |
13 | 1 | 20 | \x0000000000000001000100000000000000140000000000000000000000010000000000000000 | \x616263 | \x00011f302ff22400 | \x000000000000000100010000000000000014000100000000000001900000000000000000000000010000000000000000 | \x000000000000000100010000000000000014000100000000000001900000000000000000000000010000000000000000 |
14 | 12 | 10 | \x00000000000000010001000000000000000a0000000000000000000000010000000000000000 | \x68656c6c6f | \x00011f2dac373800 | \x00000000000000010001000000000000000a000100000000000000640000000000000000000000010000000000000000 | \x00000000000000010001000000000000000a000100000000000000640000000000000000000000010000000000000000 |