1. 17 Sep, 2017 5 commits
    • Tom Lane's avatar
      Doc: update v10 release notes through today. · 68ab9acd
      Tom Lane authored
      Add item about number of times statement-level triggers will be fired.
      Rearrange the compatibility items into (what seems to me) a less
      random ordering.
      68ab9acd
    • Tom Lane's avatar
      Allow rel_is_distinct_for() to look through RelabelType below OpExpr. · 6f44fe7f
      Tom Lane authored
      This lets it do the right thing for, eg, varchar columns.
      Back-patch to 9.5 where this logic appeared.
      
      David Rowley, per report from Kim Rose Carlsen
      
      Discussion: https://postgr.es/m/VI1PR05MB17091F9A9876528055D6A827C76D0@VI1PR05MB1709.eurprd05.prod.outlook.com
      6f44fe7f
    • Tom Lane's avatar
      Fix possible dangling pointer dereference in trigger.c. · 27c6619e
      Tom Lane authored
      AfterTriggerEndQuery correctly notes that the query_stack could get
      repalloc'd during a trigger firing, but it nonetheless passes the address
      of a query_stack entry to afterTriggerInvokeEvents, so that if such a
      repalloc occurs, afterTriggerInvokeEvents is already working with an
      obsolete dangling pointer while it scans the rest of the events.  Oops.
      The only code at risk is its "delete_ok" cleanup code, so we can
      prevent unsafe behavior by passing delete_ok = false instead of true.
      
      However, that could have a significant performance penalty, because the
      point of passing delete_ok = true is to not have to re-scan possibly
      a large number of dead trigger events on the next time through the loop.
      There's more than one way to skin that cat, though.  What we can do is
      delete all the "chunks" in the event list except the last one, since
      we know all events in them must be dead.  Deleting the chunks is work
      we'd have had to do later in AfterTriggerEndQuery anyway, and it ends
      up saving rescanning of just about the same events we'd have gotten
      rid of with delete_ok = true.
      
      In v10 and HEAD, we also have to be careful to mop up any per-table
      after_trig_events pointers that would become dangling.  This is slightly
      annoying, but I don't think that normal use-cases will traverse this code
      path often enough for it to be a performance problem.
      
      It's pretty hard to hit this in practice because of the unlikelihood
      of the query_stack getting resized at just the wrong time.  Nonetheless,
      it's definitely a live bug of ancient standing, so back-patch to all
      supported branches.
      
      Discussion: https://postgr.es/m/2891.1505419542@sss.pgh.pa.us
      27c6619e
    • Tom Lane's avatar
      Ensure that BEFORE STATEMENT triggers fire the right number of times. · fd31f9f0
      Tom Lane authored
      Commit 0f79440f introduced mechanism to keep AFTER STATEMENT triggers
      from firing more than once per statement, which was formerly possible
      if more than one FK enforcement action had to be applied to a given
      table.  Add a similar mechanism for BEFORE STATEMENT triggers, so that
      we don't have the unexpected situation of firing BEFORE STATEMENT
      triggers more often than AFTER STATEMENT.
      
      As with the previous patch, back-patch to v10.
      
      Discussion: https://postgr.es/m/22315.1505584992@sss.pgh.pa.us
      fd31f9f0
    • Tom Lane's avatar
      Fix bogus size calculation introduced by commit cc5f8136. · cad22075
      Tom Lane authored
      The elements of RecordCacheArray are TupleDesc, not TupleDesc *.
      Those are actually the same size, so that this error is harmless,
      but it's still wrong --- and it might bite us someday, if TupleDesc
      ever became a struct, say.
      
      Per Coverity.
      cad22075
  2. 16 Sep, 2017 4 commits
    • Tom Lane's avatar
      Doc: add example of transition table use in a trigger. · 936df5ba
      Tom Lane authored
      I noticed that there were exactly no complete examples of use of
      a transition table in a trigger function, and no clear description
      of just how you'd do it either.  Improve that.
      936df5ba
    • Tom Lane's avatar
      Fix SQL-spec incompatibilities in new transition table feature. · 0f79440f
      Tom Lane authored
      The standard says that all changes of the same kind (insert, update, or
      delete) caused in one table by a single SQL statement should be reported
      in a single transition table; and by that, they mean to include foreign key
      enforcement actions cascading from the statement's direct effects.  It's
      also reasonable to conclude that if the standard had wCTEs, they would say
      that effects of wCTEs applying to the same table as each other or the outer
      statement should be merged into one transition table.  We weren't doing it
      like that.
      
      Hence, arrange to merge tuples from multiple update actions into a single
      transition table as much as we can.  There is a problem, which is that if
      the firing of FK enforcement triggers and after-row triggers with
      transition tables is interspersed, we might need to report more tuples
      after some triggers have already seen the transition table.  It seems like
      a bad idea for the transition table to be mutable between trigger calls.
      There's no good way around this without a major redesign of the FK logic,
      so for now, resolve it by opening a new transition table each time this
      happens.
      
      Also, ensure that AFTER STATEMENT triggers fire just once per statement,
      or once per transition table when we're forced to make more than one.
      Previous versions of Postgres have allowed each FK enforcement query
      to cause an additional firing of the AFTER STATEMENT triggers for the
      referencing table, but that's certainly not per spec.  (We're still
      doing multiple firings of BEFORE STATEMENT triggers, though; is that
      something worth changing?)
      
      Also, forbid using transition tables with column-specific UPDATE triggers.
      The spec requires such transition tables to show only the tuples for which
      the UPDATE trigger would have fired, which means maintaining multiple
      transition tables or else somehow filtering the contents at readout.
      Maybe someday we'll bother to support that option, but it looks like a
      lot of trouble for a marginal feature.
      
      The transition tables are now managed by the AfterTriggers data structures,
      rather than being directly the responsibility of ModifyTable nodes.  This
      removes a subtransaction-lifespan memory leak introduced by my previous
      band-aid patch 3c435952.
      
      In passing, refactor the AfterTriggers data structures to reduce the
      management overhead for them, by using arrays of structs rather than
      several parallel arrays for per-query-level and per-subtransaction state.
      
      I failed to resist the temptation to do some copy-editing on the SGML
      docs about triggers, above and beyond merely documenting the effects
      of this patch.
      
      Back-patch to v10, because we don't want the semantics of transition
      tables to change post-release.
      
      Patch by me, with help and review from Thomas Munro.
      
      Discussion: https://postgr.es/m/20170909064853.25630.12825@wrigleys.postgresql.org
      0f79440f
    • Bruce Momjian's avatar
      docs: clarify pg_upgrade docs regarding standbys and rsync · 04b64b8d
      Bruce Momjian authored
      Document that rsync is an _optional_ way to upgrade standbys, suggest
      rsync option --dry-run, and mention a way of upgrading one standby from
      another using rsync.  Also clarify some instructions by specifying if
      they operate on the old or new clusters.
      
      Reported-by: Stephen Frost, Magnus Hagander
      
      Discussion: https://postgr.es/m/20170914191250.GB6595@momjian.us
      
      Backpatch-through: 9.5
      04b64b8d
    • Robert Haas's avatar
      After a MINVALUE/MAXVALUE bound, allow only more of the same. · 9361f6f5
      Robert Haas authored
      In the old syntax, which used UNBOUNDED, we had a similar restriction,
      but commit d363d42b, which changed the
      syntax, eliminated it.  Put it back.
      
      Patch by me, reviewed by Dean Rasheed.
      
      Discussion: http://postgr.es/m/CA+Tgmobs+pLPC27tS3gOpEAxAffHrq5w509cvkwTf9pF6cWYbg@mail.gmail.com
      9361f6f5
  3. 15 Sep, 2017 16 commits
  4. 14 Sep, 2017 11 commits
  5. 13 Sep, 2017 4 commits
    • Tom Lane's avatar
      Adjust unstable regression test case. · 76e134fe
      Tom Lane authored
      Test queries added by commit 69835bc8 are giving unexpected results
      on some smaller buildfarm critters.  I think probably the seqscan
      logic is kicking in to cause the scans to not start at the beginning
      of the table.  Add ORDER BY to make them be indexscans instead.
      
      Per buildfarm member chipmunk.
      76e134fe
    • Tom Lane's avatar
      Update contrib/seg for new scalarlesel/scalargesel selectivity functions. · 44ba2920
      Tom Lane authored
      I somehow missed this module in commit 7d08ce28.
      44ba2920
    • Tom Lane's avatar
      Distinguish selectivity of < from <= and > from >=. · 7d08ce28
      Tom Lane authored
      Historically, the selectivity functions have simply not distinguished
      < from <=, or > from >=, arguing that the fraction of the population that
      satisfies the "=" aspect can be considered to be vanishingly small, if the
      comparison value isn't any of the most-common-values for the variable.
      (If it is, the code path that executes the operator against each MCV will
      take care of things properly.)  But that isn't really true unless we're
      dealing with a continuum of variable values, and in practice we seldom are.
      If "x = const" would estimate a nonzero number of rows for a given const
      value, then it follows that we ought to estimate different numbers of rows
      for "x < const" and "x <= const", even if the const is not one of the MCVs.
      Handling this more honestly makes a significant difference in edge cases,
      such as the estimate for a tight range (x BETWEEN y AND z where y and z
      are close together).
      
      Hence, split scalarltsel into scalarltsel/scalarlesel, and similarly
      split scalargtsel into scalargtsel/scalargesel.  Adjust <= and >=
      operator definitions to reference the new selectivity functions.
      Improve the core ineq_histogram_selectivity() function to make a
      correction for equality.  (Along the way, I learned quite a bit about
      exactly why that function gives good answers, which I tried to memorialize
      in improved comments.)
      
      The corresponding join selectivity functions were, and remain, just stubs.
      But I chose to split them similarly, to avoid confusion and to prevent the
      need for doing this exercise again if someone ever makes them less stubby.
      
      In passing, change ineq_histogram_selectivity's clamp for extreme
      probability estimates so that it varies depending on the histogram
      size, instead of being hardwired at 0.0001.  With the default histogram
      size of 100 entries, you still get the old clamp value, but bigger
      histograms should allow us to put more faith in edge values.
      
      Tom Lane, reviewed by Aleksander Alekseev and Kuntal Ghosh
      
      Discussion: https://postgr.es/m/12232.1499140410@sss.pgh.pa.us
      7d08ce28
    • Peter Eisentraut's avatar
      doc: Remove incorrect SCRAM protocol documentation · 089880ba
      Peter Eisentraut authored
      The documentation claimed that one should send
      "pg_same_as_startup_message" as the user name in the SCRAM messages, but
      this did not match the actual implementation, so remove it.
      089880ba