forked frompostgres/postgres
- Notifications
You must be signed in to change notification settings - Fork6
Commitd3cc37f
committed
Don't scan partitioned tables.
Partitioned tables do not contain any data; only their unpartitioneddescendents need to be scanned. However, the partitioned tables stillneed to be locked, even though they're not scanned. To make thatwork, Append and MergeAppend relations now need to carry a list of(unscanned) partitioned relations that must be locked, and InitPlanmust lock all partitioned result relations.Aside from the obvious advantage of avoiding some work at executiontime, this has two other advantages. First, it may improve theplanner's decision-making in some cases since the empty relationmight throw things off. Second, it paves the way to getting rid ofthe storage for partitioned tables altogether.Amit Langote, reviewed by me.Discussion:http://postgr.es/m/6837c359-45c4-8044-34d1-736756335a15@lab.ntt.co.jp1 parentd5286aa commitd3cc37f
File tree
27 files changed
+537
-164
lines changed- src
- backend
- executor
- nodes
- optimizer
- path
- plan
- prep
- util
- utils/cache
- include
- executor
- nodes
- optimizer
- test/regress
- expected
- sql
27 files changed
+537
-164
lines changedLines changed: 21 additions & 1 deletion
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
844 | 844 |
| |
845 | 845 |
| |
846 | 846 |
| |
| 847 | + | |
| 848 | + | |
| 849 | + | |
| 850 | + | |
| 851 | + | |
| 852 | + | |
| 853 | + | |
| 854 | + | |
| 855 | + | |
| 856 | + | |
| 857 | + | |
| 858 | + | |
| 859 | + | |
| 860 | + | |
| 861 | + | |
| 862 | + | |
847 | 863 |
| |
848 | 864 |
| |
849 | 865 |
| |
| |||
858 | 874 |
| |
859 | 875 |
| |
860 | 876 |
| |
861 |
| - | |
| 877 | + | |
| 878 | + | |
| 879 | + | |
| 880 | + | |
| 881 | + | |
862 | 882 |
| |
863 | 883 |
| |
864 | 884 |
| |
|
Lines changed: 1 addition & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
161 | 161 |
| |
162 | 162 |
| |
163 | 163 |
| |
| 164 | + | |
164 | 165 |
| |
165 | 166 |
| |
166 | 167 |
| |
|
Lines changed: 56 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
43 | 43 |
| |
44 | 44 |
| |
45 | 45 |
| |
| 46 | + | |
46 | 47 |
| |
47 | 48 |
| |
48 | 49 |
| |
| |||
953 | 954 |
| |
954 | 955 |
| |
955 | 956 |
| |
| 957 | + | |
| 958 | + | |
| 959 | + | |
| 960 | + | |
| 961 | + | |
| 962 | + | |
| 963 | + | |
| 964 | + | |
| 965 | + | |
| 966 | + | |
| 967 | + | |
| 968 | + | |
| 969 | + | |
| 970 | + | |
| 971 | + | |
| 972 | + | |
| 973 | + | |
| 974 | + | |
| 975 | + | |
| 976 | + | |
| 977 | + | |
| 978 | + | |
| 979 | + | |
| 980 | + | |
| 981 | + | |
| 982 | + | |
| 983 | + | |
| 984 | + | |
| 985 | + | |
| 986 | + | |
| 987 | + | |
| 988 | + | |
| 989 | + | |
| 990 | + | |
| 991 | + | |
| 992 | + | |
| 993 | + | |
| 994 | + | |
| 995 | + | |
| 996 | + | |
| 997 | + | |
| 998 | + | |
| 999 | + | |
| 1000 | + | |
| 1001 | + | |
| 1002 | + | |
| 1003 | + | |
| 1004 | + | |
| 1005 | + | |
| 1006 | + | |
| 1007 | + | |
| 1008 | + | |
| 1009 | + | |
| 1010 | + | |
| 1011 | + |
Lines changed: 6 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
128 | 128 |
| |
129 | 129 |
| |
130 | 130 |
| |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
131 | 137 |
| |
132 | 138 |
| |
133 | 139 |
| |
|
Lines changed: 6 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
71 | 71 |
| |
72 | 72 |
| |
73 | 73 |
| |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
74 | 80 |
| |
75 | 81 |
| |
76 | 82 |
| |
|
Lines changed: 18 additions & 1 deletion
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
45 | 45 |
| |
46 | 46 |
| |
47 | 47 |
| |
| 48 | + | |
48 | 49 |
| |
49 | 50 |
| |
50 | 51 |
| |
| |||
1725 | 1726 |
| |
1726 | 1727 |
| |
1727 | 1728 |
| |
| 1729 | + | |
| 1730 | + | |
| 1731 | + | |
| 1732 | + | |
| 1733 | + | |
| 1734 | + | |
| 1735 | + | |
| 1736 | + | |
| 1737 | + | |
| 1738 | + | |
| 1739 | + | |
| 1740 | + | |
| 1741 | + | |
1728 | 1742 |
| |
1729 |
| - | |
1730 | 1743 |
| |
1731 | 1744 |
| |
1732 | 1745 |
| |
| |||
1897 | 1910 |
| |
1898 | 1911 |
| |
1899 | 1912 |
| |
| 1913 | + | |
| 1914 | + | |
| 1915 | + | |
| 1916 | + | |
1900 | 1917 |
| |
1901 | 1918 |
| |
1902 | 1919 |
| |
|
Lines changed: 21 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
90 | 90 |
| |
91 | 91 |
| |
92 | 92 |
| |
| 93 | + | |
93 | 94 |
| |
94 | 95 |
| |
95 | 96 |
| |
| |||
200 | 201 |
| |
201 | 202 |
| |
202 | 203 |
| |
| 204 | + | |
203 | 205 |
| |
204 | 206 |
| |
205 | 207 |
| |
| |||
235 | 237 |
| |
236 | 238 |
| |
237 | 239 |
| |
| 240 | + | |
238 | 241 |
| |
239 | 242 |
| |
240 | 243 |
| |
| |||
256 | 259 |
| |
257 | 260 |
| |
258 | 261 |
| |
| 262 | + | |
259 | 263 |
| |
260 | 264 |
| |
261 | 265 |
| |
| |||
2204 | 2208 |
| |
2205 | 2209 |
| |
2206 | 2210 |
| |
| 2211 | + | |
| 2212 | + | |
| 2213 | + | |
| 2214 | + | |
| 2215 | + | |
| 2216 | + | |
| 2217 | + | |
| 2218 | + | |
| 2219 | + | |
| 2220 | + | |
| 2221 | + | |
| 2222 | + | |
| 2223 | + | |
| 2224 | + | |
2207 | 2225 |
| |
2208 | 2226 |
| |
2209 | 2227 |
| |
| |||
4894 | 4912 |
| |
4895 | 4913 |
| |
4896 | 4914 |
| |
| 4915 | + | |
| 4916 | + | |
| 4917 | + | |
4897 | 4918 |
| |
4898 | 4919 |
| |
4899 | 4920 |
| |
|
Lines changed: 12 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
895 | 895 |
| |
896 | 896 |
| |
897 | 897 |
| |
| 898 | + | |
| 899 | + | |
| 900 | + | |
| 901 | + | |
| 902 | + | |
| 903 | + | |
| 904 | + | |
| 905 | + | |
| 906 | + | |
898 | 907 |
| |
899 | 908 |
| |
900 | 909 |
| |
| |||
3104 | 3113 |
| |
3105 | 3114 |
| |
3106 | 3115 |
| |
| 3116 | + | |
| 3117 | + | |
| 3118 | + | |
3107 | 3119 |
| |
3108 | 3120 |
| |
3109 | 3121 |
| |
|
Lines changed: 21 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
252 | 252 |
| |
253 | 253 |
| |
254 | 254 |
| |
| 255 | + | |
255 | 256 |
| |
256 | 257 |
| |
257 | 258 |
| |
| |||
344 | 345 |
| |
345 | 346 |
| |
346 | 347 |
| |
| 348 | + | |
347 | 349 |
| |
348 | 350 |
| |
349 | 351 |
| |
| |||
368 | 370 |
| |
369 | 371 |
| |
370 | 372 |
| |
| 373 | + | |
371 | 374 |
| |
372 | 375 |
| |
373 | 376 |
| |
| |||
380 | 383 |
| |
381 | 384 |
| |
382 | 385 |
| |
| 386 | + | |
383 | 387 |
| |
384 | 388 |
| |
385 | 389 |
| |
| |||
1808 | 1812 |
| |
1809 | 1813 |
| |
1810 | 1814 |
| |
| 1815 | + | |
1811 | 1816 |
| |
1812 | 1817 |
| |
1813 | 1818 |
| |
| |||
1818 | 1823 |
| |
1819 | 1824 |
| |
1820 | 1825 |
| |
| 1826 | + | |
1821 | 1827 |
| |
1822 | 1828 |
| |
1823 | 1829 |
| |
| |||
2023 | 2029 |
| |
2024 | 2030 |
| |
2025 | 2031 |
| |
| 2032 | + | |
2026 | 2033 |
| |
2027 | 2034 |
| |
2028 | 2035 |
| |
| |||
2099 | 2106 |
| |
2100 | 2107 |
| |
2101 | 2108 |
| |
| 2109 | + | |
2102 | 2110 |
| |
2103 | 2111 |
| |
2104 | 2112 |
| |
| |||
2137 | 2145 |
| |
2138 | 2146 |
| |
2139 | 2147 |
| |
| 2148 | + | |
2140 | 2149 |
| |
2141 | 2150 |
| |
2142 | 2151 |
| |
| |||
2419 | 2428 |
| |
2420 | 2429 |
| |
2421 | 2430 |
| |
| 2431 | + | |
| 2432 | + | |
| 2433 | + | |
| 2434 | + | |
| 2435 | + | |
| 2436 | + | |
| 2437 | + | |
| 2438 | + | |
| 2439 | + | |
2422 | 2440 |
| |
2423 | 2441 |
| |
2424 | 2442 |
| |
| |||
3906 | 3924 |
| |
3907 | 3925 |
| |
3908 | 3926 |
| |
| 3927 | + | |
| 3928 | + | |
| 3929 | + | |
3909 | 3930 |
| |
3910 | 3931 |
| |
3911 | 3932 |
| |
|
Lines changed: 4 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
1444 | 1444 |
| |
1445 | 1445 |
| |
1446 | 1446 |
| |
| 1447 | + | |
1447 | 1448 |
| |
1448 | 1449 |
| |
1449 | 1450 |
| |
| |||
1535 | 1536 |
| |
1536 | 1537 |
| |
1537 | 1538 |
| |
| 1539 | + | |
1538 | 1540 |
| |
1539 | 1541 |
| |
1540 | 1542 |
| |
| |||
1564 | 1566 |
| |
1565 | 1567 |
| |
1566 | 1568 |
| |
| 1569 | + | |
1567 | 1570 |
| |
1568 | 1571 |
| |
1569 | 1572 |
| |
| |||
1579 | 1582 |
| |
1580 | 1583 |
| |
1581 | 1584 |
| |
| 1585 | + | |
1582 | 1586 |
| |
1583 | 1587 |
| |
1584 | 1588 |
| |
|
0 commit comments
Comments
(0)