1. 05 Jan, 2012 3 commits
  2. 04 Jan, 2012 2 commits
    • Tom Lane's avatar
      Make executor's SELECT INTO code save and restore original tuple receiver. · dfd26f9c
      Tom Lane authored
      As previously coded, the QueryDesc's dest pointer was left dangling
      (pointing at an already-freed receiver object) after ExecutorEnd.  It's a
      bit astonishing that it took us this long to notice, and I'm not sure that
      the known problem case with SQL functions is the only one.  Fix it by
      saving and restoring the original receiver pointer, which seems the most
      bulletproof way of ensuring any related bugs are also covered.
      
      Per bug #6379 from Paul Ramsey.  Back-patch to 8.4 where the current
      handling of SELECT INTO was introduced.
      dfd26f9c
    • Michael Meskes's avatar
      Made code in ecpg better readable. · 10ecc0d5
      Michael Meskes authored
      10ecc0d5
  3. 03 Jan, 2012 3 commits
  4. 02 Jan, 2012 12 commits
  5. 01 Jan, 2012 3 commits
  6. 31 Dec, 2011 1 commit
  7. 30 Dec, 2011 2 commits
  8. 29 Dec, 2011 3 commits
  9. 28 Dec, 2011 1 commit
  10. 27 Dec, 2011 5 commits
  11. 26 Dec, 2011 1 commit
  12. 25 Dec, 2011 1 commit
    • Tom Lane's avatar
      Rethink representation of index clauses' mapping to index columns. · 472d3935
      Tom Lane authored
      In commit e2c2c2e8 I made use of nested
      list structures to show which clauses went with which index columns, but
      on reflection that's a data structure that only an old-line Lisp hacker
      could love.  Worse, it adds unnecessary complication to the many places
      that don't much care which clauses go with which index columns.  Revert
      to the previous arrangement of flat lists of clauses, and instead add a
      parallel integer list of column numbers.  The places that care about the
      pairing can chase both lists with forboth(), while the places that don't
      care just examine one list the same as before.
      
      The only real downside to this is that there are now two more lists that
      need to be passed to amcostestimate functions in case they care about
      column matching (which btcostestimate does, so not passing the info is not
      an option).  Rather than deal with 11-argument amcostestimate functions,
      pass just the IndexPath and expect the functions to extract fields from it.
      That gets us down to 7 arguments which is better than 11, and it seems
      more future-proof against likely additions to the information we keep
      about an index path.
      472d3935
  13. 23 Dec, 2011 2 commits
    • Tom Lane's avatar
      Improve planner's handling of duplicated index column expressions. · e2c2c2e8
      Tom Lane authored
      It's potentially useful for an index to repeat the same indexable column
      or expression in multiple index columns, if the columns have different
      opclasses.  (If they share opclasses too, the duplicate column is pretty
      useless, but nonetheless we've allowed such cases since 9.0.)  However,
      the planner failed to cope with this, because createplan.c was relying on
      simple equal() matching to figure out which index column each index qual
      is intended for.  We do have that information available upstream in
      indxpath.c, though, so the fix is to not flatten the multi-level indexquals
      list when putting it into an IndexPath.  Then we can rely on the sublist
      structure to identify target index columns in createplan.c.  There's a
      similar issue for index ORDER BYs (the KNNGIST feature), so introduce a
      multi-level-list representation for that too.  This adds a bit more
      representational overhead, but we might more or less buy that back by not
      having to search for matching index columns anymore in createplan.c;
      likewise btcostestimate saves some cycles.
      
      Per bug #6351 from Christian Rudolph.  Likely symptoms include the "btree
      index keys must be ordered by attribute" failure shown there, as well as
      "operator MMMM is not a member of opfamily NNNN".
      
      Although this is a pre-existing problem that can be demonstrated in 9.0 and
      9.1, I'm not going to back-patch it, because the API changes in the planner
      seem likely to break things such as index plugins.  The corner cases where
      this matters seem too narrow to justify possibly breaking things in a minor
      release.
      e2c2c2e8
    • Robert Haas's avatar
      Add bytea_agg, parallel to string_agg. · d5448c7d
      Robert Haas authored
      Pavel Stehule
      d5448c7d
  14. 22 Dec, 2011 1 commit