1. 14 Jun, 2017 13 commits
    • Andres Freund's avatar
      Don't force-assign transaction id when exporting a snapshot. · 6c2003f8
      Andres Freund authored
      Previously we required every exported transaction to have an xid
      assigned. That was used to check that the exporting transaction is
      still running, which in turn is needed to guarantee that that
      necessary rows haven't been removed in between exporting and importing
      the snapshot.
      
      The exported xid caused unnecessary problems with logical decoding,
      because slot creation has to wait for all concurrent xid to finish,
      which in turn serializes concurrent slot creation.   It also
      prohibited snapshots to be exported on hot-standby replicas.
      
      Instead export the virtual transactionid, which avoids the unnecessary
      serialization and the inability to export snapshots on standbys. This
      changes the file name of the exported snapshot, but since we never
      documented what that one means, that seems ok.
      
      Author: Petr Jelinek, slightly editorialized by me
      Reviewed-By: Andres Freund
      Discussion: https://postgr.es/m/f598b4b8-8cd7-0d54-0939-adda763d8c34@2ndquadrant.com
      6c2003f8
    • Peter Eisentraut's avatar
    • Peter Eisentraut's avatar
      Add missing serial comma · 4e88fe8f
      Peter Eisentraut authored
      4e88fe8f
    • Peter Eisentraut's avatar
      doc: Whitespace fixes in man pages · f0cfff9d
      Peter Eisentraut authored
      f0cfff9d
    • Robert Haas's avatar
      Teach predtest.c about CHECK clauses to fix partitioning bugs. · b08df9ca
      Robert Haas authored
      In a CHECK clause, a null result means true, whereas in a WHERE clause
      it means false.  predtest.c provided different functions depending on
      which set of semantics applied to the predicate being proved, but had
      no option to control what a null meant in the clauses provided as
      axioms.  Add one.
      
      Use that in the partitioning code when figuring out whether the
      validation scan on a new partition can be skipped.  Rip out the
      old logic that attempted (not very successfully) to compensate
      for the absence of the necessary support in predtest.c.
      
      Ashutosh Bapat and Robert Haas, reviewed by Amit Langote and
      incorporating feedback from Tom Lane.
      
      Discussion: http://postgr.es/m/CAFjFpReT_kq_uwU_B8aWDxR7jNGE=P0iELycdq5oupi=xSQTOw@mail.gmail.com
      b08df9ca
    • Tom Lane's avatar
      Improve release note text about set-returning-function changes. · a12c09ad
      Tom Lane authored
      Paul Ramsey griped about this awhile ago, but I'd been holding fire
      on changing it until we settled what to do about the CASE/COALESCE
      issue.
      
      Discussion: https://postgr.es/m/CACowWR0AMyUt5fwtvuDqWyYNdp-hQJj9XqSxJR6YM9sKWov=_w@mail.gmail.com
      a12c09ad
    • Alvaro Herrera's avatar
      Avoid bogus TwoPhaseState locking sequences · e90ceeaa
      Alvaro Herrera authored
      The optimized code in 728bd991 contains a few invalid locking
      sequences.  To wit, the original code would try to acquire an lwlock
      that it already holds.  Avoid this by moving lock acquisitions to
      higher-level code, and install appropriate assertions in low-level that
      the correct mode is held.
      
      Authors: Michael Paquier, Álvaro Herrera
      Reported-By: chuanting wang
      Bug: #14680
      Discussion: https://postgr.es/m/20170531033228.1487.10124@wrigleys.postgresql.org
      e90ceeaa
    • Peter Eisentraut's avatar
    • Tom Lane's avatar
      Fix no-longer-valid shortcuts in expression_returns_set(). · 8e72239e
      Tom Lane authored
      expression_returns_set() used to short-circuit its recursion upon
      seeing certain node types, such as DistinctExpr, that it knew the
      executor did not support set-valued arguments for.  That was never
      inherent, though, just a reflection of laziness in execQual.c.
      With the new implementation of SRFs there is no reason to think
      that any scalar-valued expression node could not have a set-valued
      subexpression, except for AggRefs and WindowFuncs where we know there
      is a parser check rejecting it.  And indeed, the shortcut causes
      unexpected failures for cases such as a SRF underneath DistinctExpr,
      because the planner stops looking for SRFs too soon.
      
      Discussion: https://postgr.es/m/5259.1497044025@sss.pgh.pa.us
      8e72239e
    • Tom Lane's avatar
      Fix violations of CatalogTupleInsert/Update/Delete abstraction. · a571c7f6
      Tom Lane authored
      In commits 2f5c9d9c and ab028965 we invented an abstraction layer
      to insulate catalog manipulations from direct heap update calls.
      But evidently some patches that hadn't landed in-tree at that point
      didn't get the memo completely.  Fix a couple of direct calls to
      simple_heap_delete to use CatalogTupleDelete instead; these appear
      to have been added in commits 7c4f5240 and 7b504eb2.  This change is
      purely cosmetic ATM, but there's no point in having an abstraction layer
      if we allow random code to break it.
      
      Masahiko Sawada and Tom Lane
      
      Discussion: https://postgr.es/m/CAD21AoDOPRSVcwbnCN3Y1n_68ATyTspsU6=ygtHz_uY0VcdZ8A@mail.gmail.com
      a571c7f6
    • Dean Rasheed's avatar
      Teach PL/pgSQL about partitioned tables. · d3c3f2b1
      Dean Rasheed authored
      Table partitioning, introduced in commit f0e44751, added a new
      relkind - RELKIND_PARTITIONED_TABLE. Update a couple of places in
      PL/pgSQL to handle it. Specifically plpgsql_parse_cwordtype() and
      build_row_from_class() needed updating in order to make table%ROWTYPE
      and table.col%TYPE work for partitioned tables.
      
      Dean Rasheed, reviewed by Amit Langote.
      
      Discussion: https://postgr.es/m/CAEZATCUnNOKN8sLML9jUzxecALWpEXK3a3W7y0PgFR4%2Buhgc%3Dg%40mail.gmail.com
      d3c3f2b1
    • Dean Rasheed's avatar
      Teach RemoveRoleFromObjectPolicy() about partitioned tables. · f356ec57
      Dean Rasheed authored
      Table partitioning, introduced in commit f0e44751, added a new
      relkind - RELKIND_PARTITIONED_TABLE. Update
      RemoveRoleFromObjectPolicy() to handle it, otherwise DROP OWNED BY
      will fail if the role has any RLS policies referring to partitioned
      tables.
      
      Dean Rasheed, reviewed by Amit Langote.
      
      Discussion: https://postgr.es/m/CAEZATCUnNOKN8sLML9jUzxecALWpEXK3a3W7y0PgFR4%2Buhgc%3Dg%40mail.gmail.com
      f356ec57
    • Tom Lane's avatar
      Disallow set-returning functions inside CASE or COALESCE. · 0436f6bd
      Tom Lane authored
      When we reimplemented SRFs in commit 69f4b9c8, our initial choice was
      to allow the behavior to vary from historical practice in cases where a
      SRF call appeared within a conditional-execution construct (currently,
      only CASE or COALESCE).  But that was controversial to begin with, and
      subsequent discussion has resulted in a consensus that it's better to
      throw an error instead of executing the query differently from before,
      so long as we can provide a reasonably clear error message and a way to
      rewrite the query.
      
      Hence, add a parser mechanism to allow detection of such cases during
      parse analysis.  The mechanism just requires storing, in the ParseState,
      a pointer to the set-returning FuncExpr or OpExpr most recently emitted
      by parse analysis.  Then the parsing functions for CASE and COALESCE can
      detect the presence of a SRF in their arguments by noting whether this
      pointer changes while analyzing their arguments.  Furthermore, if it does,
      it provides a suitable error cursor location for the complaint.  (This
      means that if there's more than one SRF in the arguments, the error will
      point at the last one to be analyzed not the first.  While connoisseurs of
      parsing behavior might find that odd, it's unlikely the average user would
      ever notice.)
      
      While at it, we can also provide more specific error messages than before
      about some pre-existing restrictions, such as no-SRFs-within-aggregates.
      Also, reject at parse time cases where a NULLIF or IS DISTINCT FROM
      construct would need to return a set.  We've never supported that, but the
      restriction is depended on in more subtle ways now, so it seems wise to
      detect it at the start.
      
      Also, provide some documentation about how to rewrite a SRF-within-CASE
      query using a custom wrapper SRF.
      
      It turns out that the information_schema.user_mapping_options view
      contained an instance of exactly the behavior we're now forbidding; but
      rewriting it makes it more clear and safer too.
      
      initdb forced because of user_mapping_options change.
      
      Patch by me, with error message suggestions from Alvaro Herrera and
      Andres Freund, pursuant to a complaint from Regina Obe.
      
      Discussion: https://postgr.es/m/000001d2d5de$d8d66170$8a832450$@pcorp.us
      0436f6bd
  2. 13 Jun, 2017 19 commits
  3. 12 Jun, 2017 8 commits