1. 29 11月, 2011 1 次提交
    • T
      Fix some bogosities in pg_dump's foreign-table support. · 9761ad67
      Tom Lane 提交于
      The server name for a foreign table was not quoted at need, as per report
      from Ronan Dunklau.  Also, queries related to FDW options were inadequately
      schema-qualified in places where the search path isn't just pg_catalog, and
      were inconsistently formatted everywhere, and we didn't always check that
      we got the expected number of rows from them.
      9761ad67
  2. 28 11月, 2011 7 次提交
    • M
      Add libpq connection option to disable SSL compression · 64aea1eb
      Magnus Hagander 提交于
      This can be used to remove the overhead of SSL compression on
      fast networks.
      
      Laurenz Albe
      64aea1eb
    • T
      Ensure that whole-row junk Vars are always of composite type. · dd3bab5f
      Tom Lane 提交于
      The EvalPlanQual machinery assumes that whole-row Vars generated for the
      outputs of non-table RTEs will be of composite types.  However, for the
      case where the RTE is a function call returning a scalar type, we were
      doing the wrong thing, as a result of sharing code with a parser case
      where the function's scalar output is wanted.  (Or at least, that's what
      that case has done historically; it does seem a bit inconsistent.)
      
      To fix, extend makeWholeRowVar's API so that it can support both use-cases.
      This fixes Belinda Cussen's report of crashes during concurrent execution
      of UPDATEs involving joins to the result of UNNEST() --- in READ COMMITTED
      mode, we'd run the EvalPlanQual machinery after a conflicting row update
      commits, and it was expecting to get a HeapTuple not a scalar datum from
      the "wholerowN" variable referencing the function RTE.
      
      Back-patch to 9.0 where the current EvalPlanQual implementation appeared.
      
      In 9.1 and up, this patch also fixes failure to attach the correct
      collation to the Var generated for a scalar-result case.  An example:
      regression=# select upper(x.*) from textcat('ab', 'cd') x;
      ERROR:  could not determine which collation to use for upper() function
      dd3bab5f
    • A
      Make pg_dumpall build with the right object files under MSVC. · 91572ee0
      Andrew Dunstan 提交于
      This fixes a longstanding but up to now benign bug in the way pg_dumpall
      was built. The bug was exposed by recent code adjustments. The Makefile
      does not use $(OBJS) to build pg_dumpall, so this fix removes their source
      files from the pg_dumpall object and adds in the one source file it
      consequently needs.
      91572ee0
    • T
      Use IEEE infinity, not 1e10, for null-and-not-null case in gistpenalty(). · 9f4563f7
      Tom Lane 提交于
      Use of a randomly chosen large value was never exactly graceful, and
      now that there are penalty functions that are intentionally using infinity,
      it doesn't seem like a good idea for null-vs-not-null to be using something
      less.
      9f4563f7
    • T
      Improve GiST range-contained-by searches by adding a flag for empty ranges. · c66e4f13
      Tom Lane 提交于
      In the original implementation, a range-contained-by search had to scan
      the entire index because an empty range could be lurking anywhere.
      Improve that by adding a flag to upper GiST entries that says whether the
      represented subtree contains any empty ranges.
      
      Also, make a simple mod to the penalty function to discourage empty ranges
      from getting pushed into subtrees without any.  This needs more work, and
      the picksplit function should be taught about it too, but that code can be
      improved without causing an on-disk compatibility break; so we'll leave it
      for another day.
      
      Since we're breaking on-disk compatibility of range values anyway, I took
      the opportunity to reorganize the range flags bits; the unused
      RANGE_xB_NULL bits are now adjacent, which might open the door for using
      them in some other way later.
      
      In passing, remove the GiST range opclass entry for <>, which doesn't seem
      like it can really be indexed usefully.
      
      Alexander Korotkov, with some editorializing by Tom
      c66e4f13
    • P
      Add pg_upgrade test suite · 08da2d28
      Peter Eisentraut 提交于
      It runs the regression tests, runs pg_upgrade on the populated
      database, and compares the before and after dumps.  While not actually
      a cross-version upgrade, this does detect omissions and bugs in the
      involved tools from time to time.  It's also possible to do a
      cross-version upgrade by manually supplying parameters.
      08da2d28
    • T
      Use the proper macro to convert a bool to a Datum. · 8722a1a0
      Tom Lane 提交于
      The original coding was
      	var->value = (Datum) state;
      which is bogus, and then in commit 2f0f7b4b
      it was "corrected" to
      	var->value = PointerGetDatum(state);
      which is a faithful translation but still wrong.
      
      This seems purely cosmetic, though, so no need for a back-patch.
      
      Pavel Stehule
      8722a1a0
  3. 27 11月, 2011 7 次提交
  4. 26 11月, 2011 8 次提交
  5. 25 11月, 2011 3 次提交
    • R
      Move "hot" members of PGPROC into a separate PGXACT array. · ed0b409d
      Robert Haas 提交于
      This speeds up snapshot-taking and reduces ProcArrayLock contention.
      Also, the PGPROC (and PGXACT) structures used by two-phase commit are
      now allocated as part of the main array, rather than in a separate
      array, and we keep ProcArray sorted in pointer order.  These changes
      are intended to minimize the number of cache lines that must be pulled
      in to take a snapshot, and testing shows a substantial increase in
      performance on both read and write workloads at high concurrencies.
      
      Pavan Deolasee, Heikki Linnakangas, Robert Haas
      ed0b409d
    • T
      Fix unsupported options in CREATE TABLE ... AS EXECUTE. · 9ed439a9
      Tom Lane 提交于
      The WITH [NO] DATA option was not supported, nor the ability to specify
      replacement column names; the former limitation wasn't even documented, as
      per recent complaint from Naoya Anzai.  Fix by moving the responsibility
      for supporting these options into the executor.  It actually takes less
      code this way ...
      
      catversion bump due to change in representation of IntoClause, which might
      affect stored rules.
      9ed439a9
    • A
      Dump an unvalidated constraint separately from its table · e90710f3
      Alvaro Herrera 提交于
      This allows possibly violating data to be imported before the constraint
      is installed.
      
      Bug reported by Thom Brown
      e90710f3
  6. 24 11月, 2011 5 次提交
    • H
      Preserve SQLSTATE when an SPI error is propagated through PL/python · f21fc7f9
      Heikki Linnakangas 提交于
      exception handler. This was a regression in 9.1, when the capability
      to catch specific SPI errors was added, so backpatch to 9.1.
      
      Mika Eloranta, with some editing by Jan Urbański.
      f21fc7f9
    • B
      Add pg_upgrade ENABLE_SAME_CATVERSION_UPGRADES macro for testing to · 5df1403b
      Bruce Momjian 提交于
      allow upgrades of the same catalog version.  (Doesn't work for
      tablespaces, as indicated by C comment.)
      5df1403b
    • T
      Some more editing of the range-types documentation. · 604d4c4c
      Tom Lane 提交于
      Be more thorough about specifying the expectations for canonical and
      subtype_diff functions, and move that info to the same place.
      604d4c4c
    • T
      Adjust range_adjacent to support different canonicalization rules. · b7056b83
      Tom Lane 提交于
      The original coding would not work for discrete ranges in which the
      canonicalization rule is to produce symmetric boundaries (either [] or ()
      style), as noted by Jeff Davis.  Florian Pflug pointed out that we could
      fix that by invoking the canonicalization function to see if the range
      "between" the two given ranges normalizes to empty.  This implementation
      of Florian's idea is a tad slower than the original code, but only in the
      case where there actually is a canonicalization function --- if not, it's
      essentially the same logic as before.
      b7056b83
    • T
      Creator of a range type must have permission to call support functions. · a912a278
      Tom Lane 提交于
      Since range types can be created by non-superusers, we need to consider
      their permissions.  Ideally we'd check this when the type is used, not
      when it's created, but that seems like much more trouble than it's worth.
      The existing restriction that the support functions be immutable already
      prevents most cases where an unauthorized call to a function might be
      thought a security issue, and the fact that the user has no access to
      the results of the system's calls to subtype_diff closes off the other
      plausible reason for concern.  So this check is basically pro-forma,
      but let's make it anyway.
      a912a278
  7. 23 11月, 2011 6 次提交
    • T
      Remove user-selectable ANALYZE option for range types. · 74c1723f
      Tom Lane 提交于
      It's not clear that a per-datatype typanalyze function would be any more
      useful than a generic typanalyze for ranges.  What *is* clear is that
      letting unprivileged users select typanalyze functions is a crash risk or
      worse.  So remove the option from CREATE TYPE AS RANGE, and instead put in
      a generic typanalyze function for ranges.  The generic function does
      nothing as yet, but hopefully we'll improve that before 9.2 release.
      74c1723f
    • T
      Remove zero- and one-argument range constructor functions. · df735844
      Tom Lane 提交于
      Per discussion, the zero-argument forms aren't really worth the catalog
      space (just write 'empty' instead).  The one-argument forms have some use,
      but they also have a serious problem with looking too much like functional
      cast notation; to the point where in many real use-cases, the parser would
      misinterpret what was wanted.
      
      Committing this as a separate patch, with the thought that we might want
      to revert part or all of it if we can think of some way around the cast
      ambiguity.
      df735844
    • T
      Improve implementation of range-contains-element tests. · cddc819e
      Tom Lane 提交于
      Implement these tests directly instead of constructing a singleton range
      and then applying range-contains.  This saves a range serialize/deserialize
      cycle as well as a couple of redundant bound-comparison steps, and adds
      very little code on net.
      
      Remove elem_contained_by_range from the GiST opclass: it doesn't belong
      there because there is no way to use it in an index clause (where the
      indexed column would have to be on the left).  Its commutator is in the
      opclass, and that's what counts.
      cddc819e
    • R
      Check for INSERT privileges in SELECT INTO / CREATE TABLE AS. · f1b4aa2a
      Robert Haas 提交于
      In the normal course of events, this matters only if ALTER DEFAULT
      PRIVILEGES has been used to revoke default INSERT permission.  Whether
      or not the new behavior is more or less likely to be what the user wants
      when dealing only with the built-in privilege facilities is arguable,
      but it's clearly better when using a loadable module such as sepgsql
      that may use the hook in ExecCheckRTPerms to enforce additional
      permissions checks.
      
      KaiGai Kohei, reviewed by Albe Laurenz
      f1b4aa2a
    • T
      Still more review for range-types patch. · 766948be
      Tom Lane 提交于
      Per discussion, relax the range input/construction rules so that the
      only hard error is lower bound > upper bound.  Cases where the lower
      bound is <= upper bound, but the range nonetheless normalizes to empty,
      are now permitted.
      
      Fix core dump in range_adjacent when bounds are infinite.  Marginal
      cleanup of regression test cases, some more code commenting.
      766948be
    • P
      Small markup and wording improvement · 024ea25c
      Peter Eisentraut 提交于
      024ea25c
  8. 22 11月, 2011 3 次提交
    • S
      Continue to allow VACUUM to mark last block of index dirty · 2d2841a5
      Simon Riggs 提交于
      even when there is no work to do. Further analysis required.
      Revert of patch c1458cc4
      2d2841a5
    • T
      More code review for rangetypes patch. · a4ffcc8e
      Tom Lane 提交于
      Fix up some infelicitous coding in DefineRange, and add some missing error
      checks.  Rearrange operator strategy number assignments for GiST anyrange
      opclass so that they don't make such a mess of opr_sanity's table of
      operator names associated with different strategy numbers.  Assign
      hopefully-temporary selectivity estimators to range operators that didn't
      have one --- poor as the estimates are, they're still a lot better than the
      default 0.5 estimate, and they'll shut up the opr_sanity test that wants to
      see selectivity estimators on all built-in operators.
      a4ffcc8e
    • T
      Fix citext upgrade script to update derived copies of pg_type.typcollation. · 9b97b7f8
      Tom Lane 提交于
      If the existing citext type has not merely been created, but used in any
      tables, then the upgrade script wasn't doing enough.  We have to update
      attcollation for each citext table column, and indcollation for each citext
      index column, as well.  Per report from Rudolf van der Leeden.
      9b97b7f8