forked frompostgres/postgres
- Notifications
You must be signed in to change notification settings - Fork6
Commit34768ee
committed
Add temporal FOREIGN KEY contraints
Add PERIOD clause to foreign key constraint definitions. This issupported for range and multirange types. Temporal foreign keys checkfor range containment instead of equality.This feature matches the behavior of the SQL standard temporal foreignkeys, but it works on PostgreSQL's native ranges instead of SQL's"periods", which don't exist in PostgreSQL (yet).Reference actions ON {UPDATE,DELETE} {CASCADE,SET NULL,SET DEFAULT}are not supported yet.Author: Paul A. Jungwirth <pj@illuminatedcomputing.com>Reviewed-by: Peter Eisentraut <peter@eisentraut.org>Reviewed-by: jian he <jian.universality@gmail.com>Discussion:https://www.postgresql.org/message-id/flat/CA+renyUApHgSZF9-nd-a0+OPGharLQLO=mDHcY4_qQ0+noCUVg@mail.gmail.com1 parentb1fe8ef commit34768ee
File tree
16 files changed
+2790
-118
lines changed- contrib/btree_gist
- expected
- sql
- doc/src/sgml
- ref
- src
- backend
- catalog
- commands
- parser
- utils/adt
- include
- catalog
- commands
- nodes
- parser
- test/regress
- expected
- sql
16 files changed
+2790
-118
lines changedLines changed: 48 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
42 | 42 |
| |
43 | 43 |
| |
44 | 44 |
| |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + |
Lines changed: 28 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
23 | 23 |
| |
24 | 24 |
| |
25 | 25 |
| |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + |
Lines changed: 2 additions & 1 deletion
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
2728 | 2728 |
| |
2729 | 2729 |
| |
2730 | 2730 |
| |
2731 |
| - | |
| 2731 | + | |
| 2732 | + | |
2732 | 2733 |
| |
2733 | 2734 |
| |
2734 | 2735 |
| |
|
Lines changed: 39 additions & 4 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
81 | 81 |
| |
82 | 82 |
| |
83 | 83 |
| |
84 |
| - | |
| 84 | + | |
85 | 85 |
| |
86 | 86 |
| |
87 | 87 |
| |
| |||
1152 | 1152 |
| |
1153 | 1153 |
| |
1154 | 1154 |
| |
1155 |
| - | |
1156 |
| - | |
| 1155 | + | |
| 1156 | + | |
1157 | 1157 |
| |
1158 | 1158 |
| |
1159 | 1159 |
| |
| |||
1169 | 1169 |
| |
1170 | 1170 |
| |
1171 | 1171 |
| |
1172 |
| - | |
| 1172 | + | |
| 1173 | + | |
| 1174 | + | |
| 1175 | + | |
| 1176 | + | |
| 1177 | + | |
| 1178 | + | |
| 1179 | + | |
| 1180 | + | |
| 1181 | + | |
| 1182 | + | |
| 1183 | + | |
| 1184 | + | |
| 1185 | + | |
| 1186 | + | |
| 1187 | + | |
| 1188 | + | |
| 1189 | + | |
| 1190 | + | |
| 1191 | + | |
| 1192 | + | |
| 1193 | + | |
| 1194 | + | |
| 1195 | + | |
1173 | 1196 |
| |
1174 | 1197 |
| |
1175 | 1198 |
| |
| |||
1243 | 1266 |
| |
1244 | 1267 |
| |
1245 | 1268 |
| |
| 1269 | + | |
| 1270 | + | |
| 1271 | + | |
| 1272 | + | |
1246 | 1273 |
| |
1247 | 1274 |
| |
1248 | 1275 |
| |
| |||
1254 | 1281 |
| |
1255 | 1282 |
| |
1256 | 1283 |
| |
| 1284 | + | |
| 1285 | + | |
| 1286 | + | |
| 1287 | + | |
1257 | 1288 |
| |
1258 | 1289 |
| |
1259 | 1290 |
| |
| |||
1267 | 1298 |
| |
1268 | 1299 |
| |
1269 | 1300 |
| |
| 1301 | + | |
| 1302 | + | |
| 1303 | + | |
| 1304 | + | |
1270 | 1305 |
| |
1271 | 1306 |
| |
1272 | 1307 |
| |
|
Lines changed: 58 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
15 | 15 |
| |
16 | 16 |
| |
17 | 17 |
| |
| 18 | + | |
18 | 19 |
| |
19 | 20 |
| |
20 | 21 |
| |
| |||
1649 | 1650 |
| |
1650 | 1651 |
| |
1651 | 1652 |
| |
| 1653 | + | |
| 1654 | + | |
| 1655 | + | |
| 1656 | + | |
| 1657 | + | |
| 1658 | + | |
| 1659 | + | |
| 1660 | + | |
| 1661 | + | |
| 1662 | + | |
| 1663 | + | |
| 1664 | + | |
| 1665 | + | |
| 1666 | + | |
| 1667 | + | |
| 1668 | + | |
| 1669 | + | |
| 1670 | + | |
| 1671 | + | |
| 1672 | + | |
| 1673 | + | |
| 1674 | + | |
| 1675 | + | |
| 1676 | + | |
| 1677 | + | |
| 1678 | + | |
| 1679 | + | |
| 1680 | + | |
| 1681 | + | |
| 1682 | + | |
| 1683 | + | |
| 1684 | + | |
| 1685 | + | |
| 1686 | + | |
| 1687 | + | |
| 1688 | + | |
| 1689 | + | |
| 1690 | + | |
| 1691 | + | |
| 1692 | + | |
| 1693 | + | |
| 1694 | + | |
| 1695 | + | |
| 1696 | + | |
| 1697 | + | |
| 1698 | + | |
| 1699 | + | |
| 1700 | + | |
| 1701 | + | |
| 1702 | + | |
| 1703 | + | |
| 1704 | + | |
| 1705 | + | |
| 1706 | + | |
| 1707 | + | |
| 1708 | + | |
| 1709 | + | |
1652 | 1710 |
| |
1653 | 1711 |
| |
1654 | 1712 |
| |
|
Lines changed: 18 additions & 13 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
2185 | 2185 |
| |
2186 | 2186 |
| |
2187 | 2187 |
| |
2188 |
| - | |
| 2188 | + | |
2189 | 2189 |
| |
2190 | 2190 |
| |
2191 | 2191 |
| |
| |||
2425 | 2425 |
| |
2426 | 2426 |
| |
2427 | 2427 |
| |
2428 |
| - | |
| 2428 | + | |
2429 | 2429 |
| |
2430 | 2430 |
| |
2431 | 2431 |
| |
| |||
2438 | 2438 |
| |
2439 | 2439 |
| |
2440 | 2440 |
| |
2441 |
| - | |
| 2441 | + | |
2442 | 2442 |
| |
2443 | 2443 |
| |
2444 | 2444 |
| |
2445 | 2445 |
| |
2446 | 2446 |
| |
2447 | 2447 |
| |
2448 |
| - | |
| 2448 | + | |
2449 | 2449 |
| |
2450 | 2450 |
| |
2451 | 2451 |
| |
| |||
2468 | 2468 |
| |
2469 | 2469 |
| |
2470 | 2470 |
| |
2471 |
| - | |
2472 |
| - | |
2473 |
| - | |
| 2471 | + | |
| 2472 | + | |
| 2473 | + | |
2474 | 2474 |
| |
2475 | 2475 |
| |
2476 |
| - | |
2477 |
| - | |
2478 | 2476 |
| |
2479 | 2477 |
| |
2480 |
| - | |
| 2478 | + | |
| 2479 | + | |
| 2480 | + | |
| 2481 | + | |
| 2482 | + | |
| 2483 | + | |
| 2484 | + | |
| 2485 | + | |
2481 | 2486 |
| |
2482 | 2487 |
| |
2483 | 2488 |
| |
| |||
2490 | 2495 |
| |
2491 | 2496 |
| |
2492 | 2497 |
| |
2493 |
| - | |
2494 |
| - | |
2495 |
| - | |
| 2498 | + | |
| 2499 | + | |
| 2500 | + | |
2496 | 2501 |
| |
2497 | 2502 |
| |
2498 | 2503 |
| |
|
0 commit comments
Comments
(0)