- Notifications
You must be signed in to change notification settings - Fork4.9k
Commit0f57382
committed
Use ExprStates for hashing in GROUP BY and SubPlans
This speeds up obtaining hash values for GROUP BY and hashed SubPlans byusing the ExprState support for hashing, thus allowing JIT compilation forobtaining hash values for these operations.This, even without JIT compilation, has been shown to improve HashAggregate performance in some cases by around 15% and hashed NOT INqueries in one case by over 30%, however, real-world cases are likely tosee smaller gains as the test cases used were purposefully designed tohave high hashing overheads by keeping the hash table small to preventadditional memory overheads that would be a factor when working with largehash tables.In passing, fix a hypothetical bug in ExecBuildHash32Expr() so that theinitial value is stored directly in the ExprState's result field ifthere are no expressions to hash. None of the current users of thisfunction use an initial value, so the bug is only hypothetical.Reviewed-by: Andrei Lepikhov <lepihov@gmail.com>Discussion:https://postgr.es/m/CAApHDvpYSO3kc9UryMevWqthTBrxgfd9djiAjKHMPUSQeX9vdQ@mail.gmail.com1 parenta435674 commit0f57382
File tree
5 files changed
+224
-66
lines changed- src
- backend/executor
- include
- executor
- nodes
5 files changed
+224
-66
lines changedLines changed: 155 additions & 0 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
3978 | 3978 |
| |
3979 | 3979 |
| |
3980 | 3980 |
| |
| 3981 | + | |
| 3982 | + | |
| 3983 | + | |
| 3984 | + | |
| 3985 | + | |
| 3986 | + | |
| 3987 | + | |
| 3988 | + | |
| 3989 | + | |
| 3990 | + | |
| 3991 | + | |
| 3992 | + | |
| 3993 | + | |
| 3994 | + | |
| 3995 | + | |
| 3996 | + | |
| 3997 | + | |
| 3998 | + | |
| 3999 | + | |
| 4000 | + | |
| 4001 | + | |
| 4002 | + | |
| 4003 | + | |
| 4004 | + | |
| 4005 | + | |
| 4006 | + | |
| 4007 | + | |
| 4008 | + | |
| 4009 | + | |
| 4010 | + | |
| 4011 | + | |
| 4012 | + | |
| 4013 | + | |
| 4014 | + | |
| 4015 | + | |
| 4016 | + | |
| 4017 | + | |
| 4018 | + | |
| 4019 | + | |
| 4020 | + | |
| 4021 | + | |
| 4022 | + | |
| 4023 | + | |
| 4024 | + | |
| 4025 | + | |
| 4026 | + | |
| 4027 | + | |
| 4028 | + | |
| 4029 | + | |
| 4030 | + | |
| 4031 | + | |
| 4032 | + | |
| 4033 | + | |
| 4034 | + | |
| 4035 | + | |
| 4036 | + | |
| 4037 | + | |
| 4038 | + | |
| 4039 | + | |
| 4040 | + | |
| 4041 | + | |
| 4042 | + | |
| 4043 | + | |
| 4044 | + | |
| 4045 | + | |
| 4046 | + | |
| 4047 | + | |
| 4048 | + | |
| 4049 | + | |
| 4050 | + | |
| 4051 | + | |
| 4052 | + | |
| 4053 | + | |
| 4054 | + | |
| 4055 | + | |
| 4056 | + | |
| 4057 | + | |
| 4058 | + | |
| 4059 | + | |
| 4060 | + | |
| 4061 | + | |
| 4062 | + | |
| 4063 | + | |
| 4064 | + | |
| 4065 | + | |
| 4066 | + | |
| 4067 | + | |
| 4068 | + | |
| 4069 | + | |
| 4070 | + | |
| 4071 | + | |
| 4072 | + | |
| 4073 | + | |
| 4074 | + | |
| 4075 | + | |
| 4076 | + | |
| 4077 | + | |
| 4078 | + | |
| 4079 | + | |
| 4080 | + | |
| 4081 | + | |
| 4082 | + | |
| 4083 | + | |
| 4084 | + | |
| 4085 | + | |
| 4086 | + | |
| 4087 | + | |
| 4088 | + | |
| 4089 | + | |
| 4090 | + | |
| 4091 | + | |
| 4092 | + | |
| 4093 | + | |
| 4094 | + | |
| 4095 | + | |
| 4096 | + | |
| 4097 | + | |
| 4098 | + | |
| 4099 | + | |
| 4100 | + | |
| 4101 | + | |
| 4102 | + | |
| 4103 | + | |
| 4104 | + | |
| 4105 | + | |
| 4106 | + | |
| 4107 | + | |
| 4108 | + | |
| 4109 | + | |
| 4110 | + | |
| 4111 | + | |
| 4112 | + | |
| 4113 | + | |
| 4114 | + | |
| 4115 | + | |
| 4116 | + | |
| 4117 | + | |
| 4118 | + | |
| 4119 | + | |
| 4120 | + | |
| 4121 | + | |
| 4122 | + | |
| 4123 | + | |
| 4124 | + | |
| 4125 | + | |
| 4126 | + | |
| 4127 | + | |
| 4128 | + | |
| 4129 | + | |
| 4130 | + | |
| 4131 | + | |
| 4132 | + | |
| 4133 | + | |
| 4134 | + | |
| 4135 | + | |
3981 | 4136 |
| |
3982 | 4137 |
| |
3983 | 4138 |
| |
|
Lines changed: 34 additions & 48 deletions
Original file line number | Diff line number | Diff line change | |
---|---|---|---|
| |||
169 | 169 |
| |
170 | 170 |
| |
171 | 171 |
| |
| 172 | + | |
172 | 173 |
| |
173 | 174 |
| |
174 | 175 |
| |
| |||
183 | 184 |
| |
184 | 185 |
| |
185 | 186 |
| |
186 |
| - | |
187 | 187 |
| |
188 | 188 |
| |
189 | 189 |
| |
190 | 190 |
| |
191 | 191 |
| |
192 | 192 |
| |
193 |
| - | |
| 193 | + | |
194 | 194 |
| |
195 | 195 |
| |
196 | 196 |
| |
| |||
202 | 202 |
| |
203 | 203 |
| |
204 | 204 |
| |
205 |
| - | |
206 |
| - | |
207 |
| - | |
| 205 | + | |
208 | 206 |
| |
209 | 207 |
| |
210 | 208 |
| |
| |||
225 | 223 |
| |
226 | 224 |
| |
227 | 225 |
| |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
228 | 236 |
| |
229 | 237 |
| |
230 | 238 |
| |
| |||
316 | 324 |
| |
317 | 325 |
| |
318 | 326 |
| |
319 |
| - | |
| 327 | + | |
320 | 328 |
| |
321 | 329 |
| |
322 | 330 |
| |
| |||
342 | 350 |
| |
343 | 351 |
| |
344 | 352 |
| |
345 |
| - | |
| 353 | + | |
346 | 354 |
| |
347 | 355 |
| |
348 | 356 |
| |
| |||
370 | 378 |
| |
371 | 379 |
| |
372 | 380 |
| |
373 |
| - | |
| 381 | + | |
374 | 382 |
| |
375 | 383 |
| |
376 | 384 |
| |
| |||
386 | 394 |
| |
387 | 395 |
| |
388 | 396 |
| |
389 |
| - | |
390 |
| - | |
| 397 | + | |
| 398 | + | |
391 | 399 |
| |
392 | 400 |
| |
393 | 401 |
| |
394 | 402 |
| |
395 | 403 |
| |
396 |
| - | |
| 404 | + | |
397 | 405 |
| |
398 | 406 |
| |
399 | 407 |
| |
| |||
404 | 412 |
| |
405 | 413 |
| |
406 | 414 |
| |
407 |
| - | |
| 415 | + | |
408 | 416 |
| |
409 | 417 |
| |
410 | 418 |
| |
| |||
421 | 429 |
| |
422 | 430 |
| |
423 | 431 |
| |
424 |
| - | |
| 432 | + | |
425 | 433 |
| |
426 | 434 |
| |
427 | 435 |
| |
428 | 436 |
| |
429 | 437 |
| |
430 | 438 |
| |
431 |
| - | |
432 |
| - | |
433 |
| - | |
| 439 | + | |
434 | 440 |
| |
435 |
| - | |
436 |
| - | |
| 441 | + | |
437 | 442 |
| |
438 | 443 |
| |
439 | 444 |
| |
440 | 445 |
| |
441 |
| - | |
442 |
| - | |
| 446 | + | |
| 447 | + | |
| 448 | + | |
| 449 | + | |
443 | 450 |
| |
444 | 451 |
| |
445 | 452 |
| |
| |||
449 | 456 |
| |
450 | 457 |
| |
451 | 458 |
| |
452 |
| - | |
| 459 | + | |
453 | 460 |
| |
454 |
| - | |
455 |
| - | |
456 |
| - | |
457 |
| - | |
458 |
| - | |
459 |
| - | |
460 |
| - | |
461 |
| - | |
462 |
| - | |
463 |
| - | |
464 |
| - | |
465 |
| - | |
466 |
| - | |
467 |
| - | |
468 |
| - | |
469 |
| - | |
470 |
| - | |
471 |
| - | |
472 |
| - | |
473 |
| - | |
474 |
| - | |
475 |
| - | |
476 |
| - | |
| 461 | + | |
| 462 | + | |
| 463 | + | |
477 | 464 |
| |
478 | 465 |
| |
479 | 466 |
| |
480 |
| - | |
481 |
| - | |
482 |
| - | |
483 |
| - | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
484 | 470 |
| |
485 | 471 |
| |
486 | 472 |
| |
|
0 commit comments
Comments
(0)