- Notifications
You must be signed in to change notification settings - Fork28
Commitf18c944
committed
postgres_fdw: Add ORDER BY to some remote SQL queries.
If the join problem's entire ORDER BY clause can be pushed to theremote server, consider a path that adds this ORDER BY clause. Ifuse_remote_estimate is on, we cost this path using an additionalremote EXPLAIN. If not, we just estimate that the path costs 20%more, which is intended to be large enough that we won't request aremote sort when it's not helpful, but small enough that we'll havethe remote side do the sort when in doubt. In some cases, the remotesort might actually be free, because the remote query plan mighthappen to produce output that is ordered the way we need, but withoutremote estimates we have no way of knowing that.It might also be useful to request sorted output from the remote sideif it enables an efficient merge join, but this patch doesn't attemptto handle that case.Ashutosh Bapat with revisions by me. Also reviewed by Fabrízio de RoyesMello and Jeevan Chalke.1 parentfc0b893 commitf18c944
File tree
5 files changed
+222
-30
lines changed- contrib/postgres_fdw
- expected
- sql
5 files changed
+222
-30
lines changedLines changed: 53 additions & 3 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
193 | 193 |
| |
194 | 194 |
| |
195 | 195 |
| |
196 |
| - | |
197 |
| - | |
198 |
| - | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
199 | 202 |
| |
200 | 203 |
| |
201 | 204 |
| |
| |||
1877 | 1880 |
| |
1878 | 1881 |
| |
1879 | 1882 |
| |
| 1883 | + | |
| 1884 | + | |
| 1885 | + | |
| 1886 | + | |
| 1887 | + | |
| 1888 | + | |
| 1889 | + | |
| 1890 | + | |
| 1891 | + | |
| 1892 | + | |
| 1893 | + | |
| 1894 | + | |
| 1895 | + | |
| 1896 | + | |
| 1897 | + | |
| 1898 | + | |
| 1899 | + | |
| 1900 | + | |
| 1901 | + | |
| 1902 | + | |
| 1903 | + | |
| 1904 | + | |
| 1905 | + | |
| 1906 | + | |
| 1907 | + | |
| 1908 | + | |
| 1909 | + | |
| 1910 | + | |
| 1911 | + | |
| 1912 | + | |
| 1913 | + | |
| 1914 | + | |
| 1915 | + | |
| 1916 | + | |
| 1917 | + | |
| 1918 | + | |
| 1919 | + | |
| 1920 | + | |
| 1921 | + | |
| 1922 | + | |
| 1923 | + | |
| 1924 | + | |
| 1925 | + | |
| 1926 | + | |
| 1927 | + | |
| 1928 | + | |
| 1929 | + |
Lines changed: 43 additions & 21 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
134 | 134 |
| |
135 | 135 |
| |
136 | 136 |
| |
137 |
| - | |
| 137 | + | |
138 | 138 |
| |
139 |
| - | |
140 |
| - | |
| 139 | + | |
| 140 | + | |
141 | 141 |
| |
142 |
| - | |
143 |
| - | |
144 |
| - | |
145 |
| - | |
| 142 | + | |
| 143 | + | |
146 | 144 |
| |
147 | 145 |
| |
148 | 146 |
| |
| |||
159 | 157 |
| |
160 | 158 |
| |
161 | 159 |
| |
162 |
| - | |
| 160 | + | |
| 161 | + | |
163 | 162 |
| |
164 | 163 |
| |
165 | 164 |
| |
166 |
| - | |
| 165 | + | |
167 | 166 |
| |
168 |
| - | |
169 |
| - | |
| 167 | + | |
| 168 | + | |
170 | 169 |
| |
171 |
| - | |
| 170 | + | |
172 | 171 |
| |
173 | 172 |
| |
174 | 173 |
| |
175 |
| - | |
| 174 | + | |
176 | 175 |
| |
177 | 176 |
| |
178 | 177 |
| |
| |||
189 | 188 |
| |
190 | 189 |
| |
191 | 190 |
| |
192 |
| - | |
193 |
| - | |
| 191 | + | |
| 192 | + | |
194 | 193 |
| |
195 | 194 |
| |
196 |
| - | |
| 195 | + | |
197 | 196 |
| |
198 |
| - | |
199 |
| - | |
200 |
| - | |
201 |
| - | |
202 |
| - | |
| 197 | + | |
| 198 | + | |
203 | 199 |
| |
204 | 200 |
| |
205 | 201 |
| |
| |||
650 | 646 |
| |
651 | 647 |
| |
652 | 648 |
| |
| 649 | + | |
| 650 | + | |
| 651 | + | |
| 652 | + | |
| 653 | + | |
| 654 | + | |
| 655 | + | |
| 656 | + | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
| 666 | + | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
653 | 675 |
| |
654 | 676 |
| |
655 | 677 |
| |
|
Lines changed: 113 additions & 3 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
47 | 47 |
| |
48 | 48 |
| |
49 | 49 |
| |
| 50 | + | |
| 51 | + | |
| 52 | + | |
50 | 53 |
| |
51 | 54 |
| |
52 | 55 |
| |
| |||
296 | 299 |
| |
297 | 300 |
| |
298 | 301 |
| |
| 302 | + | |
299 | 303 |
| |
300 | 304 |
| |
301 | 305 |
| |
| |||
497 | 501 |
| |
498 | 502 |
| |
499 | 503 |
| |
500 |
| - | |
| 504 | + | |
501 | 505 |
| |
502 | 506 |
| |
503 | 507 |
| |
| |||
527 | 531 |
| |
528 | 532 |
| |
529 | 533 |
| |
530 |
| - | |
| 534 | + | |
531 | 535 |
| |
532 | 536 |
| |
533 | 537 |
| |
| |||
546 | 550 |
| |
547 | 551 |
| |
548 | 552 |
| |
| 553 | + | |
549 | 554 |
| |
550 | 555 |
| |
551 | 556 |
| |
| |||
563 | 568 |
| |
564 | 569 |
| |
565 | 570 |
| |
| 571 | + | |
| 572 | + | |
| 573 | + | |
| 574 | + | |
| 575 | + | |
| 576 | + | |
| 577 | + | |
| 578 | + | |
| 579 | + | |
| 580 | + | |
| 581 | + | |
| 582 | + | |
| 583 | + | |
| 584 | + | |
| 585 | + | |
| 586 | + | |
| 587 | + | |
| 588 | + | |
| 589 | + | |
| 590 | + | |
| 591 | + | |
| 592 | + | |
| 593 | + | |
| 594 | + | |
| 595 | + | |
| 596 | + | |
| 597 | + | |
| 598 | + | |
| 599 | + | |
| 600 | + | |
| 601 | + | |
| 602 | + | |
| 603 | + | |
| 604 | + | |
| 605 | + | |
| 606 | + | |
| 607 | + | |
| 608 | + | |
| 609 | + | |
| 610 | + | |
| 611 | + | |
| 612 | + | |
| 613 | + | |
| 614 | + | |
| 615 | + | |
| 616 | + | |
| 617 | + | |
| 618 | + | |
| 619 | + | |
| 620 | + | |
| 621 | + | |
| 622 | + | |
| 623 | + | |
| 624 | + | |
566 | 625 |
| |
567 | 626 |
| |
568 | 627 |
| |
| |||
710 | 769 |
| |
711 | 770 |
| |
712 | 771 |
| |
713 |
| - | |
| 772 | + | |
714 | 773 |
| |
715 | 774 |
| |
716 | 775 |
| |
| |||
811 | 870 |
| |
812 | 871 |
| |
813 | 872 |
| |
| 873 | + | |
| 874 | + | |
| 875 | + | |
| 876 | + | |
814 | 877 |
| |
815 | 878 |
| |
816 | 879 |
| |
| |||
1728 | 1791 |
| |
1729 | 1792 |
| |
1730 | 1793 |
| |
| 1794 | + | |
1731 | 1795 |
| |
1732 | 1796 |
| |
1733 | 1797 |
| |
| |||
1780 | 1844 |
| |
1781 | 1845 |
| |
1782 | 1846 |
| |
| 1847 | + | |
| 1848 | + | |
| 1849 | + | |
1783 | 1850 |
| |
1784 | 1851 |
| |
1785 | 1852 |
| |
| |||
1837 | 1904 |
| |
1838 | 1905 |
| |
1839 | 1906 |
| |
| 1907 | + | |
| 1908 | + | |
| 1909 | + | |
| 1910 | + | |
| 1911 | + | |
| 1912 | + | |
| 1913 | + | |
| 1914 | + | |
| 1915 | + | |
| 1916 | + | |
| 1917 | + | |
| 1918 | + | |
| 1919 | + | |
| 1920 | + | |
| 1921 | + | |
1840 | 1922 |
| |
1841 | 1923 |
| |
1842 | 1924 |
| |
| |||
3002 | 3084 |
| |
3003 | 3085 |
| |
3004 | 3086 |
| |
| 3087 | + | |
| 3088 | + | |
| 3089 | + | |
| 3090 | + | |
| 3091 | + | |
| 3092 | + | |
| 3093 | + | |
| 3094 | + | |
| 3095 | + | |
| 3096 | + | |
| 3097 | + | |
| 3098 | + | |
| 3099 | + | |
| 3100 | + | |
| 3101 | + | |
| 3102 | + | |
| 3103 | + | |
| 3104 | + | |
| 3105 | + | |
| 3106 | + | |
| 3107 | + | |
| 3108 | + | |
| 3109 | + | |
| 3110 | + | |
| 3111 | + | |
| 3112 | + | |
| 3113 | + | |
| 3114 | + |
Lines changed: 3 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
74 | 74 |
| |
75 | 75 |
| |
76 | 76 |
| |
| 77 | + | |
| 78 | + | |
| 79 | + | |
77 | 80 |
| |
78 | 81 |
|
0 commit comments
Comments
(0)