forked frompostgres/postgres
- Notifications
You must be signed in to change notification settings - Fork6
Commitcbfa92c
committed
Improve index-only scans to avoid repeated access to the index page.
We copy all the matched tuples off the page during _bt_readpage, instead ofexpensively re-locking the page during each subsequent tuple fetch. Thiscosts a bit more local storage, but not more than 2*BLCKSZ worth, and thereduction in LWLock traffic is certainly worth that. What's more, thislets us get rid of the API wart in the original patch that said an index AMcould randomly decline to supply an index tuple despite having assertedpg_am.amcanreturn. That will be important for future improvements in theindex-only-scan feature, since the executor will now be able to rely onhaving the index data available.1 parent45401c1 commitcbfa92c
File tree
8 files changed
+136
-135
lines changed- doc/src/sgml
- src
- backend
- access
- index
- nbtree
- executor
- include/access
8 files changed
+136
-135
lines changedLines changed: 6 additions & 5 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
394 | 394 |
| |
395 | 395 |
| |
396 | 396 |
| |
397 |
| - | |
| 397 | + | |
398 | 398 |
| |
399 |
| - | |
400 |
| - | |
401 |
| - | |
402 |
| - | |
| 399 | + | |
| 400 | + | |
| 401 | + | |
| 402 | + | |
| 403 | + | |
403 | 404 |
| |
404 | 405 |
| |
405 | 406 |
| |
|
Lines changed: 4 additions & 3 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
443 | 443 |
| |
444 | 444 |
| |
445 | 445 |
| |
446 |
| - | |
447 |
| - | |
448 |
| - | |
| 446 | + | |
| 447 | + | |
| 448 | + | |
| 449 | + | |
449 | 450 |
| |
450 | 451 |
| |
451 | 452 |
| |
|
Lines changed: 28 additions & 92 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
73 | 73 |
| |
74 | 74 |
| |
75 | 75 |
| |
76 |
| - | |
77 | 76 |
| |
78 | 77 |
| |
79 | 78 |
| |
| |||
311 | 310 |
| |
312 | 311 |
| |
313 | 312 |
| |
314 |
| - | |
315 |
| - | |
316 |
| - | |
317 |
| - | |
318 |
| - | |
319 |
| - | |
320 |
| - | |
321 |
| - | |
322 |
| - | |
323 |
| - | |
324 |
| - | |
325 |
| - | |
326 |
| - | |
327 |
| - | |
328 | 313 |
| |
329 | 314 |
| |
330 | 315 |
| |
331 |
| - | |
332 |
| - | |
333 |
| - | |
334 |
| - | |
335 |
| - | |
336 |
| - | |
337 |
| - | |
338 |
| - | |
339 |
| - | |
340 |
| - | |
341 |
| - | |
342 |
| - | |
343 |
| - | |
344 |
| - | |
345 |
| - | |
346 |
| - | |
347 |
| - | |
348 |
| - | |
349 |
| - | |
350 |
| - | |
351 |
| - | |
352 |
| - | |
353 |
| - | |
354 |
| - | |
355 |
| - | |
356 |
| - | |
357 |
| - | |
358 |
| - | |
359 |
| - | |
360 |
| - | |
361 |
| - | |
362 |
| - | |
363 |
| - | |
364 |
| - | |
365 |
| - | |
366 |
| - | |
367 |
| - | |
368 |
| - | |
369 |
| - | |
370 |
| - | |
371 |
| - | |
372 |
| - | |
373 |
| - | |
374 |
| - | |
375 |
| - | |
376 |
| - | |
377 |
| - | |
378 |
| - | |
379 |
| - | |
380 |
| - | |
381 |
| - | |
382 |
| - | |
383 |
| - | |
384 |
| - | |
385 |
| - | |
386 |
| - | |
387 |
| - | |
388 |
| - | |
389 |
| - | |
390 |
| - | |
391 |
| - | |
392 |
| - | |
393 |
| - | |
394 |
| - | |
395 |
| - | |
396 |
| - | |
397 |
| - | |
398 |
| - | |
399 |
| - | |
400 |
| - | |
401 |
| - | |
402 | 316 |
| |
403 | 317 |
| |
404 | 318 |
| |
| |||
471 | 385 |
| |
472 | 386 |
| |
473 | 387 |
| |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
474 | 397 |
| |
475 | 398 |
| |
476 | 399 |
| |
| |||
505 | 428 |
| |
506 | 429 |
| |
507 | 430 |
| |
| 431 | + | |
| 432 | + | |
| 433 | + | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
| 437 | + | |
| 438 | + | |
| 439 | + | |
| 440 | + | |
| 441 | + | |
| 442 | + | |
508 | 443 |
| |
509 | 444 |
| |
510 | 445 |
| |
| |||
544 | 479 |
| |
545 | 480 |
| |
546 | 481 |
| |
| 482 | + | |
547 | 483 |
| |
548 | 484 |
| |
549 | 485 |
| |
550 | 486 |
| |
| 487 | + | |
| 488 | + | |
| 489 | + | |
551 | 490 |
| |
552 | 491 |
| |
553 |
| - | |
554 |
| - | |
555 |
| - | |
556 |
| - | |
557 |
| - | |
558 |
| - | |
559 | 492 |
| |
560 | 493 |
| |
561 | 494 |
| |
| |||
626 | 559 |
| |
627 | 560 |
| |
628 | 561 |
| |
| 562 | + | |
| 563 | + | |
| 564 | + | |
629 | 565 |
| |
630 | 566 |
| |
631 | 567 |
| |
|
Lines changed: 54 additions & 14 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
26 | 26 |
| |
27 | 27 |
| |
28 | 28 |
| |
| 29 | + | |
| 30 | + | |
29 | 31 |
| |
30 | 32 |
| |
31 | 33 |
| |
| |||
429 | 431 |
| |
430 | 432 |
| |
431 | 433 |
| |
432 |
| - | |
433 |
| - | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
434 | 437 |
| |
435 | 438 |
| |
436 | 439 |
| |
| |||
456 | 459 |
| |
457 | 460 |
| |
458 | 461 |
| |
| 462 | + | |
459 | 463 |
| |
460 | 464 |
| |
461 | 465 |
| |
| |||
912 | 916 |
| |
913 | 917 |
| |
914 | 918 |
| |
915 |
| - | |
| 919 | + | |
| 920 | + | |
| 921 | + | |
| 922 | + | |
916 | 923 |
| |
917 | 924 |
| |
918 | 925 |
| |
| |||
925 | 932 |
| |
926 | 933 |
| |
927 | 934 |
| |
928 |
| - | |
| 935 | + | |
| 936 | + | |
929 | 937 |
| |
930 | 938 |
| |
931 | 939 |
| |
| |||
934 | 942 |
| |
935 | 943 |
| |
936 | 944 |
| |
| 945 | + | |
937 | 946 |
| |
938 | 947 |
| |
939 | 948 |
| |
| |||
967 | 976 |
| |
968 | 977 |
| |
969 | 978 |
| |
970 |
| - | |
| 979 | + | |
| 980 | + | |
| 981 | + | |
| 982 | + | |
971 | 983 |
| |
972 | 984 |
| |
973 | 985 |
| |
| |||
996 | 1008 |
| |
997 | 1009 |
| |
998 | 1010 |
| |
| 1011 | + | |
999 | 1012 |
| |
1000 | 1013 |
| |
1001 | 1014 |
| |
| |||
1013 | 1026 |
| |
1014 | 1027 |
| |
1015 | 1028 |
| |
| 1029 | + | |
| 1030 | + | |
| 1031 | + | |
1016 | 1032 |
| |
1017 | 1033 |
| |
1018 | 1034 |
| |
| |||
1022 | 1038 |
| |
1023 | 1039 |
| |
1024 | 1040 |
| |
1025 |
| - | |
| 1041 | + | |
| 1042 | + | |
1026 | 1043 |
| |
1027 | 1044 |
| |
1028 |
| - | |
1029 |
| - | |
1030 |
| - | |
| 1045 | + | |
1031 | 1046 |
| |
1032 | 1047 |
| |
1033 | 1048 |
| |
| |||
1054 | 1069 |
| |
1055 | 1070 |
| |
1056 | 1071 |
| |
1057 |
| - | |
| 1072 | + | |
| 1073 | + | |
1058 | 1074 |
| |
1059 | 1075 |
| |
1060 |
| - | |
1061 | 1076 |
| |
1062 |
| - | |
1063 |
| - | |
| 1077 | + | |
1064 | 1078 |
| |
1065 | 1079 |
| |
1066 | 1080 |
| |
| |||
1081 | 1095 |
| |
1082 | 1096 |
| |
1083 | 1097 |
| |
| 1098 | + | |
| 1099 | + | |
| 1100 | + | |
| 1101 | + | |
| 1102 | + | |
| 1103 | + | |
| 1104 | + | |
| 1105 | + | |
| 1106 | + | |
| 1107 | + | |
| 1108 | + | |
| 1109 | + | |
| 1110 | + | |
| 1111 | + | |
| 1112 | + | |
| 1113 | + | |
| 1114 | + | |
| 1115 | + | |
| 1116 | + | |
1084 | 1117 |
| |
1085 | 1118 |
| |
1086 | 1119 |
| |
| |||
1119 | 1152 |
| |
1120 | 1153 |
| |
1121 | 1154 |
| |
| 1155 | + | |
| 1156 | + | |
| 1157 | + | |
1122 | 1158 |
| |
1123 | 1159 |
| |
1124 | 1160 |
| |
| |||
1428 | 1464 |
| |
1429 | 1465 |
| |
1430 | 1466 |
| |
| 1467 | + | |
1431 | 1468 |
| |
1432 | 1469 |
| |
1433 | 1470 |
| |
| |||
1505 | 1542 |
| |
1506 | 1543 |
| |
1507 | 1544 |
| |
1508 |
| - | |
| 1545 | + | |
| 1546 | + | |
| 1547 | + | |
| 1548 | + | |
1509 | 1549 |
| |
1510 | 1550 |
| |
1511 | 1551 |
|
0 commit comments
Comments
(0)