1. 12 Aug, 2019 2 commits
    • Tom Lane's avatar
      Rationalize use of list_concat + list_copy combinations. · 5ee190f8
      Tom Lane authored
      In the wake of commit 1cff1b95, the result of list_concat no longer
      shares the ListCells of the second input.  Therefore, we can replace
      "list_concat(x, list_copy(y))" with just "list_concat(x, y)".
      
      To improve call sites that were list_copy'ing the first argument,
      or both arguments, invent "list_concat_copy()" which produces a new
      list sharing no ListCells with either input.  (This is a bit faster
      than "list_concat(list_copy(x), y)" because it makes the result list
      the right size to start with.)
      
      In call sites that were not list_copy'ing the second argument, the new
      semantics mean that we are usually leaking the second List's storage,
      since typically there is no remaining pointer to it.  We considered
      inventing another list_copy variant that would list_free the second
      input, but concluded that for most call sites it isn't worth worrying
      about, given the relative compactness of the new List representation.
      (Note that in cases where such leakage would happen, the old code
      already leaked the second List's header; so we're only discussing
      the size of the leak not whether there is one.  I did adjust two or
      three places that had been troubling to free that header so that
      they manually free the whole second List.)
      
      Patch by me; thanks to David Rowley for review.
      
      Discussion: https://postgr.es/m/11587.1550975080@sss.pgh.pa.us
      5ee190f8
    • Alexander Korotkov's avatar
      Fix string comparison in jsonpath · 251c8e39
      Alexander Korotkov authored
      Take into account pg_server_to_any() may return input string "as is".
      
      Reported-by: Andrew Dunstan, Thomas Munro
      Discussion: https://postgr.es/m/0ed83a33-d900-466a-880a-70ef456c721f%402ndQuadrant.com
      Author: Alexander Korotkov, Thomas Munro
      Backpatch-through: 12
      251c8e39
  2. 11 Aug, 2019 2 commits
    • Tom Lane's avatar
      Partially revert "Insert temporary debugging output in regression tests." · b43f7c11
      Tom Lane authored
      This reverts much of commit f03a9ca4,
      but leaves the relpages/reltuples probe in select_parallel.sql.
      The pg_stat_all_tables probes are unstable enough to be annoying,
      and it no longer seems likely that they will teach us anything more
      about the underlying problem.  I'd still like some more confirmation
      though that the observed plan instability is caused by VACUUM leaving
      relpages/reltuples as zero for one of these tables.
      
      Discussion: https://postgr.es/m/CA+hUKG+0CxrKRWRMf5ymN3gm+BECHna2B-q1w8onKBep4HasUw@mail.gmail.com
      b43f7c11
    • Alexander Korotkov's avatar
      Adjust string comparison in jsonpath · d54ceb9e
      Alexander Korotkov authored
      We have implemented jsonpath string comparison using default database locale.
      However, standard requires us to compare Unicode codepoints.  This commit
      implements that, but for performance reasons we still use per-byte comparison
      for "==" operator.  Thus, for consistency other comparison operators do per-byte
      comparison if Unicode codepoints appear to be equal.
      
      In some edge cases, when same Unicode codepoints have different binary
      representations in database encoding, we diverge standard to achieve better
      performance of "==" operator.  In future to implement strict standard
      conformance, we can do normalization of input JSON strings.
      
      Original patch was written by Nikita Glukhov, rewritten by me.
      
      Reported-by: Markus Winand
      Discussion: https://postgr.es/m/8B7FA3B4-328D-43D7-95A8-37B8891B8C78%40winand.at
      Author: Nikita Glukhov, Alexander Korotkov
      Backpatch-through: 12
      d54ceb9e
  3. 10 Aug, 2019 2 commits
    • Tom Lane's avatar
      Fix "ANALYZE t, t" inside a transaction block. · cabe0f29
      Tom Lane authored
      This failed with either "tuple already updated by self" or "duplicate
      key value violates unique constraint", depending on whether the table
      had previously been analyzed or not.  The reason is that ANALYZE tried
      to insert or update the same pg_statistic rows twice, and there was no
      CommandCounterIncrement between.  So add one.  The same case works fine
      outside a transaction block, because then there's a whole transaction
      boundary between, as a consequence of the way VACUUM works.
      
      This issue has been latent all along, but the problem was unreachable
      before commit 11d8d72c added the ability to specify multiple tables
      in ANALYZE.  We could, perhaps, alternatively fix it by adding code to
      de-duplicate the list of VacuumRelations --- but that would add a
      lot of overhead to work around dumb commands, so it's not attractive.
      
      Per bug #15946 from Yaroslav Schekin.  Back-patch to v11.
      
      (Note: in v11 I also back-patched the test added by commit 23224563;
      otherwise the problem doesn't manifest in the test I added, because
      "vactst" is empty when the tests for multiple ANALYZE targets are
      reached.  That seems like not a very good thing anyway, so I did this
      rather than rethinking the choice of test case.)
      
      Discussion: https://postgr.es/m/15946-5c7570a2884a26cf@postgresql.org
      cabe0f29
    • Peter Geoghegan's avatar
      Rename tuplesort.c's SortTuple.tupindex field. · d8cd68c8
      Peter Geoghegan authored
      Rename the "tupindex" field from tuplesort.c's SortTuple struct to
      "srctape", since it can only ever be used to store a source/input tape
      number when merging external sort runs.  This has been the case since
      commit 8b304b8b, which removed replacement selection sort from
      tuplesort.c.
      d8cd68c8
  4. 09 Aug, 2019 3 commits
  5. 08 Aug, 2019 4 commits
  6. 07 Aug, 2019 9 commits
    • Tom Lane's avatar
      Doc: document permissions required for ANALYZE. · e94cd0a8
      Tom Lane authored
      VACUUM's reference page had this text, but ANALYZE's didn't.  That's
      a clear oversight given that section 5.7 explicitly delegates the
      responsibility to define permissions requirements to the individual
      commands' man pages.
      
      Per gripe from Isaac Morland.  Back-patch to all supported branches.
      
      Discussion: https://postgr.es/m/CAMsGm5fp3oBUs-2iRfii0iEO=fZuJALVyM2zJLhNTjG34gpAVQ@mail.gmail.com
      e94cd0a8
    • Alvaro Herrera's avatar
      Remove unnecessary #include <limits.h> · e1f4c481
      Alvaro Herrera authored
      This include was probably copied from tuplestore.c, but it's not needed.
      
      Extracted from a larger patch submitted by vignesh C <vignesh21@gmail.com>
      
      Discussion: https://postgr.es/m/CALDaNm1B9naPDTm3ox1m_yZvOm3KA5S4kZQSWWAeLHAQ=3gV1Q@mail.gmail.com
      e1f4c481
    • Alvaro Herrera's avatar
    • Alvaro Herrera's avatar
      Apply constraint exclusion more generally in partitioning · 4e85642d
      Alvaro Herrera authored
      We were applying constraint exclusion on the partition constraint when
      generating pruning steps for a clause, but only for the rather
      restricted situation of them being boolean OR operators; however it is
      possible to have differently shaped clauses that also benefit from
      constraint exclusion.  This applies particularly to the default
      partition since their constraints are in essence a long list of OR'ed
      subclauses ... but it applies to other cases too.  So in certain cases
      we're scanning partitions that we don't need to.
      
      Remove the specialized code in OR clauses, and add a generally
      applicable test of the clause refuting the partition constraint; mark
      the whole pruning operation as contradictory if it hits.
      
      This has the unwanted side-effect of testing some (most? all?)
      constraints more than once if constraint_exclusion=on.  That seems
      unavoidable as far as I can tell without some additional work, but
      that's not the recommended setting for that parameter anyway.
      However, because this imposes additional processing cost for all
      queries using partitioned tables, I decided not to backpatch this
      change.
      
      Author: Amit Langote, Yuzuko Hosoya, Álvaro Herrera
      Reviewers: Shawn Wang, Thibaut Madeleine, Yoshikazu Imai, Kyotaro
      Horiguchi; they were also uncredited reviewers for commit 489247b0.
      Discussion: https://postgr.es/m/9bb31dfe-b0d0-53f3-3ea6-e64b811424cf@lab.ntt.co.jp
      4e85642d
    • Alexander Korotkov's avatar
      Fix some typos in jsonpath documentation · 1f33f211
      Alexander Korotkov authored
      Discussion: https://postgr.es/m/8B7FA3B4-328D-43D7-95A8-37B8891B8C78%40winand.at
      Author: Markus Winand
      Backpatch-through: 12
      1f33f211
    • Etsuro Fujita's avatar
      Fix typos in comments. · 68343b4a
      Etsuro Fujita authored
      68343b4a
    • Heikki Linnakangas's avatar
      Fix predicate-locking of HOT updated rows. · 1169fcf1
      Heikki Linnakangas authored
      In serializable mode, heap_hot_search_buffer() incorrectly acquired a
      predicate lock on the root tuple, not the returned tuple that satisfied
      the visibility checks. As explained in README-SSI, the predicate lock does
      not need to be copied or extended to other tuple versions, but for that to
      work, the correct, visible, tuple version must be locked in the first
      place.
      
      The original SSI commit had this bug in it, but it was fixed back in 2013,
      in commit 81fbbfe3. But unfortunately, it was reintroduced a few months
      later in commit b89e1510. Wising up from that, add a regression test
      to cover this, so that it doesn't get reintroduced again. Also, move the
      code that sets 't_self', so that it happens at the same time that the
      other HeapTuple fields are set, to make it more clear that all the code in
      the loop operate on the "current" tuple in the chain, not the root tuple.
      
      Bug spotted by Andres Freund, analysis and original fix by Thomas Munro,
      test case and some additional changes to the fix by Heikki Linnakangas.
      Backpatch to all supported versions (9.4).
      
      Discussion: https://www.postgresql.org/message-id/20190731210630.nqhszuktygwftjty%40alap3.anarazel.de
      1169fcf1
    • Michael Paquier's avatar
      Fix some incorrect parsing of time with time zone strings · 64579be6
      Michael Paquier authored
      When parsing a timetz string with a dynamic timezone abbreviation or a
      timezone not specified, it was possible to generate incorrect timestamps
      based on a date which uses some non-initialized variables if the input
      string did not specify fully a date to parse.  This is already checked
      when a full timezone spec is included in the input string, but the two
      other cases mentioned above missed the same checks.
      
      This gets fixed by generating an error as this input is invalid, or in
      short when a date is not fully specified.
      
      Valgrind was complaining about this problem.
      
      Bug: #15910
      Author: Alexander Lakhin
      Discussion: https://postgr.es/m/15910-2eba5106b9aa0c61@postgresql.org
      Backpatch-through: 9.4
      64579be6
    • Michael Paquier's avatar
      Adjust tuple data lookup logic in multi-insert logical decoding · 75c1921c
      Michael Paquier authored
      As of now, logical decoding of a multi-insert has been scanning all
      xl_multi_insert_tuple entries only if XLH_INSERT_CONTAINS_NEW_TUPLE was
      getting set in the record.  This is not an issue on HEAD as multi-insert
      records are not used for system catalogs, but the logical decoding logic
      includes all the code necessary to handle that properly, except that the
      code missed to iterate correctly over all xl_multi_insert_tuple entries
      when the flag is not set.  Hence, when trying to use multi-insert for
      system catalogs, an assertion would be triggered.
      
      An upcoming patch is going to make use of multi-insert for system
      catalogs, and this fixes the logic to make sure that all entries are
      scanned correctly without softening the existing assertions.
      
      Reported-by: Daniel Gustafsson
      Author: Michael Paquier
      Reviewed-by: Daniel Gustafsson
      Discussion: https://postgr.es/m/CBFFD532-C033-49EB-9A5A-F67EAEE9EB0B@yesql.se
      75c1921c
  7. 06 Aug, 2019 3 commits
    • Tom Lane's avatar
      Fix intarray's GiST opclasses to not fail for empty arrays with <@. · efc77cf5
      Tom Lane authored
      contrib/intarray considers "arraycol <@ constant-array" to be indexable,
      but its GiST opclass code fails to reliably find index entries for empty
      array values (which of course should trivially match such queries).
      This is because the test condition to see whether we should descend
      through a non-leaf node is wrong.
      
      Unfortunately, empty array entries could be anywhere in the index,
      as these index opclasses are currently designed.  So there's no way
      to fix this except by lobotomizing <@ indexscans to scan the whole
      index ... which is what this patch does.  That's pretty unfortunate:
      the performance is now actually worse than a seqscan, in most cases.
      We'd be better off to remove <@ from the GiST opclasses entirely,
      and perhaps a future non-back-patchable patch will do so.
      
      In the meantime, applications whose performance is adversely impacted
      have a couple of options.  They could switch to a GIN index, which
      doesn't have this bug, or they could replace "arraycol <@ constant-array"
      with "arraycol <@ constant-array AND arraycol && constant-array".
      That will provide about the same performance as before, and it will find
      all non-empty subsets of the given constant-array, which is all that
      could reliably be expected of the query before.
      
      While at it, add some more regression test cases to improve code
      coverage of contrib/intarray.
      
      In passing, adjust resize_intArrayType so that when it's returning an
      empty array, it uses construct_empty_array for that rather than
      cowboy hacking on the input array.  While the hack produces an array
      that looks valid for most purposes, it isn't bitwise equal to empty
      arrays produced by other code paths, which could have subtle odd
      effects.  I don't think this code path is performance-critical
      enough to justify such shortcuts.  (Back-patch this part only as far
      as v11; before commit 01783ac3 we were not careful about this in
      other intarray code paths either.)
      
      Back-patch the <@ fixes to all supported versions, since this was
      broken from day one.
      
      Patch by me; thanks to Alexander Korotkov for review.
      
      Discussion: https://postgr.es/m/458.1565114141@sss.pgh.pa.us
      efc77cf5
    • Tom Lane's avatar
      Save Kerberos and LDAP daemon logs where the buildfarm can find them. · 4ecd05cb
      Tom Lane authored
      src/test/kerberos and src/test/ldap try to run private authentication
      servers, which of course might fail.  The logs from these servers
      were being dropped into the tmp_check/ subdirectory, but they should
      be put in tmp_check/log/, because the buildfarm will only capture
      log files in that subdirectory.  Without the log output there's
      little hope of diagnosing buildfarm failures related to these servers.
      
      Backpatch to v11 where these test suites were added.
      
      Discussion: https://postgr.es/m/16017.1565047605@sss.pgh.pa.us
      4ecd05cb
    • Michael Paquier's avatar
  8. 05 Aug, 2019 6 commits
    • Peter Geoghegan's avatar
      Show specific OID suggestion in unused_oids output. · 98eab30b
      Peter Geoghegan authored
      Commit a6417078 established a new project policy around OID assignment:
      new patches are encouraged to choose a random OID in the 8000..9999
      range when a manually-assigned OID is required (if multiple OIDs are
      required, a consecutive block of OIDs starting from the random point
      should be used).  Catalog entries added by committed patches that use
      OIDs from this "unstable" range are renumbered after feature freeze.
      This practice minimizes OID collisions among concurrently-developed
      patches.
      
      Show a specific random OID suggestion when the unused_oids script is
      run.  This makes it easy for patch authors to use a random OID from the
      unstable range, per the new policy.
      
      Author: Julien Rouhaud, Peter Geoghegan
      Reviewed-By: Tom Lane
      Discussion: https://postgr.es/m/CAH2-WzkkRs2ScmuBQ7xWi7xzp7fC1B3w0Nt8X+n4rBw5k+Z=zA@mail.gmail.com
      98eab30b
    • Tom Lane's avatar
      Fix choice of comparison operators for cross-type hashed subplans. · 4766dce0
      Tom Lane authored
      Commit bf6c614a rearranged the lookup of the comparison operators
      needed in a hashed subplan, and in so doing, broke the cross-type
      case: it caused the original LHS-vs-RHS operator to be used to compare
      hash table entries too (which of course are all of the RHS type).
      This leads to C functions being passed a Datum that is not of the
      type they expect, with the usual hazards of crashes and unauthorized
      server memory disclosure.
      
      For the set of hashable cross-type operators present in v11 core
      Postgres, this bug is nearly harmless on 64-bit machines, which
      may explain why it escaped earlier detection.  But it is a live
      security hazard on 32-bit machines; and of course there may be
      extensions that add more hashable cross-type operators, which
      would increase the risk.
      
      Reported by Andreas Seltenreich.  Back-patch to v11 where the
      problem came in.
      
      Security: CVE-2019-10209
      4766dce0
    • Noah Misch's avatar
      Require the schema qualification in pg_temp.type_name(arg). · ffa2d37e
      Noah Misch authored
      Commit aa27977f introduced this
      restriction for pg_temp.function_name(arg); do likewise for types
      created in temporary schemas.  Programs that this breaks should add
      "pg_temp." schema qualification or switch to arg::type_name syntax.
      Back-patch to 9.4 (all supported versions).
      
      Reviewed by Tom Lane.  Reported by Tom Lane.
      
      Security: CVE-2019-10208
      ffa2d37e
    • Michael Paquier's avatar
      Add safeguards in LSN, numeric and float calculation for custom errors · a76cfba6
      Michael Paquier authored
      Those data types use parsing and/or calculation wrapper routines which
      can generate some generic error messages in the event of a failure.  The
      caller of these routines can also pass a pointer variable settable by
      the routine to track if an error has happened, letting the caller decide
      what to do in the event of an error and what error message to generate.
      
      Those routines have been slacking the initialization of the tracking
      flag, which can be confusing when reading the code, so add some
      safeguards against calls of these parsing routines which could lead to a
      dubious result.
      
      The LSN parsing gains an assertion to make sure that the tracking flag
      is set, while numeric and float paths initialize the flag to a saner
      state.
      
      Author: Jeevan Ladhe
      Reviewed-by: Álvaro Herrera, Michael Paquier
      Discussion: https://postgr.es/m/CAOgcT0NOM9oR0Hag_3VpyW0uF3iCU=BDUFSPfk9JrWXRcWQHqw@mail.gmail.com
      a76cfba6
    • Michael Paquier's avatar
      Fix tab completion for ALTER LANGUAGE in psql · 05ba8370
      Michael Paquier authored
      OWNER_TO was used for the completion, which is not a supported grammar,
      but OWNER TO is.
      
      This error has been introduced by d37b816d, so backpatch down to 9.6.
      
      Author: Alexander Lakhin
      Discussion: https://postgr.es/m/7ab243e0-116d-3e44-d120-76b3df7abefd@gmail.com
      Backpatch-through: 9.6
      05ba8370
    • Michael Paquier's avatar
      Fix inconsistencies and typos in the tree, take 9 · 8548ddc6
      Michael Paquier authored
      This addresses more issues with code comments, variable names and
      unreferenced variables.
      
      Author: Alexander Lakhin
      Discussion: https://postgr.es/m/7ab243e0-116d-3e44-d120-76b3df7abefd@gmail.com
      8548ddc6
  9. 04 Aug, 2019 6 commits
    • Tomas Vondra's avatar
      Revert "Add log_statement_sample_rate parameter" · 75506195
      Tomas Vondra authored
      This reverts commit 88bdbd3f.
      
      As committed, statement sampling used the existing duration threshold
      (log_min_duration_statement) when decide which statements to sample.
      The issue is that even the longest statements are subject to sampling,
      and so may not end up logged. An improvement was proposed, introducing
      a second duration threshold, but it would not be backwards compatible.
      So we've decided to revert this feature - the separate threshold should
      be part of the feature itself.
      
      Discussion: https://postgr.es/m/CAFj8pRDS8tQ3Wviw9%3DAvODyUciPSrGeMhJi_WPE%2BEB8%2B4gLL-Q%40mail.gmail.com
      75506195
    • Tomas Vondra's avatar
      Revert "Silence compiler warning" · 4f9ed8f3
      Tomas Vondra authored
      This reverts commit 9dc12258.
      
      As committed, statement sampling used the existing duration threshold
      (log_min_duration_statement) when decide which statements to sample.
      The issue is that even the longest statements are subject to sampling,
      and so may not end up logged. An improvement was proposed, introducing
      a second duration threshold, but it would not be backwards compatible.
      So we've decided to revert this feature - the separate threshold should
      be part of the feature itself.
      
      Discussion: https://postgr.es/m/CAFj8pRDS8tQ3Wviw9%3DAvODyUciPSrGeMhJi_WPE%2BEB8%2B4gLL-Q%40mail.gmail.com
      4f9ed8f3
    • Tom Lane's avatar
      Fix handling of "undef" in contrib/jsonb_plperl. · e0f50488
      Tom Lane authored
      Perl has multiple internal representations of "undef", and just
      testing for SvTYPE(x) == SVt_NULL doesn't recognize all of them,
      leading to "cannot transform this Perl type to jsonb" errors.
      Use the approved test SvOK() instead.
      
      Report and patch by Ivan Panchenko.  Back-patch to v11 where
      this module was added.
      
      Discussion: https://postgr.es/m/1564783533.324795401@f193.i.mail.ru
      e0f50488
    • Tom Lane's avatar
      Avoid picking already-bound TCP ports in kerberos and ldap test suites. · 803466b6
      Tom Lane authored
      src/test/kerberos and src/test/ldap need to run a private authentication
      server of the relevant type, for which they need a free TCP port.
      They were just picking a random port number in 48K-64K, which works
      except when something's already using the particular port.  Notably,
      the probability of failure rises dramatically if one simply runs those
      tests in a tight loop, because each test cycle leaves behind a bunch of
      high ports that are transiently in TIME_WAIT state.
      
      To fix, split out the code that PostgresNode.pm already had for
      identifying a free TCP port number, so that it can be invoked to choose
      a port for the KDC or LDAP server.  This isn't 100% bulletproof, since
      conceivably something else on the machine could grab the port between
      the time we check and the time we actually start the server.  But that's
      a pretty short window, so in practice this should be good enough.
      
      Back-patch to v11 where these test suites were added.
      
      Patch by me, reviewed by Andrew Dunstan.
      
      Discussion: https://postgr.es/m/3397.1564872168@sss.pgh.pa.us
      803466b6
    • Alvaro Herrera's avatar
      Improve pruning of a default partition · 489247b0
      Alvaro Herrera authored
      When querying a partitioned table containing a default partition, we
      were wrongly deciding to include it in the scan too early in the
      process, failing to exclude it in some cases.  If we reinterpret the
      PruneStepResult.scan_default flag slightly, we can do a better job at
      detecting that it can be excluded.  The change is that we avoid setting
      the flag for that pruning step unless the step absolutely requires the
      default partition to be scanned (in contrast with the previous
      arrangement, which was to set it unless the step was able to prune it).
      So get_matching_partitions() must explicitly check the partition that
      each returned bound value corresponds to in order to determine whether
      the default one needs to be included, rather than relying on the flag
      from the final step result.
      
      Author: Yuzuko Hosoya <hosoya.yuzuko@lab.ntt.co.jp>
      Reviewed-by: default avatarAmit Langote <Langote_Amit_f8@lab.ntt.co.jp>
      Discussion: https://postgr.es/m/00e601d4ca86$932b8bc0$b982a340$@lab.ntt.co.jp
      489247b0
    • Michael Paquier's avatar
      Refactor BuildIndexInfo() with the new makeIndexInfo() · 69edf4f8
      Michael Paquier authored
      This portion of the code got forgotten in 7cce1593 which has introduced a
      new routine to build this node, and this finishes the unification of the
      places where IndexInfo is initialized.
      
      Author: Michael Paquier
      Discussion: https://postgr.es/m/20190801041322.GA3435@paquier.xyz
      69edf4f8
  10. 02 Aug, 2019 2 commits
    • Andres Freund's avatar
      Fix representation of hash keys in Hash/HashJoin nodes. · 2abd7ae9
      Andres Freund authored
      In 5f32b29c I changed the creation of HashState.hashkeys to
      actually use HashState as the parent (instead of HashJoinState, which
      was incorrect, as they were executed below HashState), to fix the
      problem of hashkeys expressions otherwise relying on slot types
      appropriate for HashJoinState, rather than HashState as would be
      correct. That reliance was only introduced in 12, which is why it
      previously worked to use HashJoinState as the parent (although I'd be
      unsurprised if there were problematic cases).
      
      Unfortunately that's not a sufficient solution, because before this
      commit, the to-be-hashed expressions referenced inner/outer as
      appropriate for the HashJoin, not Hash. That didn't have obvious bad
      consequences, because the slots containing the tuples were put into
      ecxt_innertuple when hashing a tuple for HashState (even though Hash
      doesn't have an inner plan).
      
      There are less common cases where this can cause visible problems
      however (rather than just confusion when inspecting such executor
      trees). E.g. "ERROR: bogus varno: 65000", when explaining queries
      containing a HashJoin where the subsidiary Hash node's hash keys
      reference a subplan. While normally hashkeys aren't displayed by
      EXPLAIN, if one of those expressions references a subplan, that
      subplan may be printed as part of the Hash node - which then failed
      because an inner plan was referenced, and Hash doesn't have that.
      
      It seems quite possible that there's other broken cases, too.
      
      Fix the problem by properly splitting the expression for the HashJoin
      and Hash nodes at plan time, and have them reference the proper
      subsidiary node. While other workarounds are possible, fixing this
      correctly seems easy enough. It was a pretty ugly hack to have
      ExecInitHashJoin put the expression into the already initialized
      HashState, in the first place.
      
      I decided to not just split inner/outer hashkeys inside
      make_hashjoin(), but also to separate out hashoperators and
      hashcollations at plan time. Otherwise we would have ended up having
      two very similar loops, one at plan time and the other during executor
      startup. The work seems to more appropriately belong to plan time,
      anyway.
      
      Reported-By: Nikita Glukhov, Alexander Korotkov
      Author: Andres Freund
      Reviewed-By: Tom Lane, in an earlier version
      Discussion: https://postgr.es/m/CAPpHfdvGVegF_TKKRiBrSmatJL2dR9uwFCuR+teQ_8tEXU8mxg@mail.gmail.com
      Backpatch: 12-
      2abd7ae9
    • Michael Paquier's avatar
      Fix format truncation issue from ECPG test · a9f301df
      Michael Paquier authored
      This fixes one warning generated by GCC and present in the test case
      array part of ECPG.  This likely got missed in past fixes like 3a4b8919
      because the compilation of those tests is not done by default.
      
      Reported-by: Sergei Kornilov
      Discussion: https://postgr.es/m/14951331562847675@sas2-a1efad875d04.qloud-c.yandex.net
      a9f301df
  11. 01 Aug, 2019 1 commit