1. 20 Aug, 2000 4 commits
  2. 19 Aug, 2000 1 commit
  3. 13 Aug, 2000 1 commit
    • Tom Lane's avatar
      Clean up handling of variable-free qual clauses. System now does the · 37168b8d
      Tom Lane authored
      right thing with variable-free clauses that contain noncachable functions,
      such as 'WHERE random() < 0.5' --- these are evaluated once per
      potential output tuple.  Expressions that contain only Params are
      now candidates to be indexscan quals --- for example, 'var = ($1 + 1)'
      can now be indexed.  Cope with RelabelType nodes atop potential indexscan
      variables --- this oversight prevents 7.0.* from recognizing some
      potentially indexscanable situations.
      37168b8d
  4. 12 Aug, 2000 2 commits
  5. 11 Aug, 2000 4 commits
  6. 10 Aug, 2000 1 commit
  7. 09 Aug, 2000 1 commit
  8. 08 Aug, 2000 2 commits
  9. 07 Aug, 2000 9 commits
  10. 06 Aug, 2000 7 commits
    • Thomas G. Lockhart's avatar
      Implement LIKE/ESCAPE. Change parser to use like()/notlike() · 259489ba
      Thomas G. Lockhart authored
       rather than the "~~" operator; this made it easy to add ESCAPE features.
      Implement ILIKE, NOT ILIKE, and the ESCAPE clause for them.
       afaict this is not MultiByte clean, but lots of other stuff isn't either.
      Fix up underlying support code for LIKE/NOT LIKE.
       Things should be faster and does not require internal string copying.
      Update regression test to add explicit checks for
       LIKE/NOT LIKE/ILIKE/NOT ILIKE.
      Remove colon and semi-colon operators as threatened in 7.0.
      Implement SQL99 COMMIT/AND NO CHAIN.
       Throw elog(ERROR) on COMMIT/AND CHAIN per spec
       since we don't yet support it.
      Implement SQL99 CREATE/DROP SCHEMA as equivalent to CREATE DATABASE.
       This is only a stopgap or demo since schemas will have another
       implementation soon.
      Remove a few unused production rules to get rid of warnings
       which crept in on the last commit.
      Fix up tabbing in some places by removing embedded spaces.
      259489ba
    • Thomas G. Lockhart's avatar
      Implement LIKE/ESCAPE. Change parser to use like()/notlike() · 30ab107d
      Thomas G. Lockhart authored
       rather than the "~~" operator; this made it easy to add ESCAPE features.
      Implement ILIKE, NOT ILIKE, and the ESCAPE clause for them.
       afaict this is not MultiByte clean, but lots of other stuff isn't either.
      Fix up underlying support code for LIKE/NOT LIKE.
       Things should be faster and does not require internal string copying.
      Update regression test to add explicit checks for
       LIKE/NOT LIKE/ILIKE/NOT ILIKE.
      Remove colon and semi-colon operators as threatened in 7.0.
      Implement SQL99 COMMIT/AND NO CHAIN.
       Throw elog(ERROR) on COMMIT/AND CHAIN per spec
       since we don't yet support it.
      Implement SQL99 CREATE/DROP SCHEMA as equivalent to CREATE DATABASE.
       This is only a stopgap or demo since schemas will have another
       implementation soon.
      Remove a few unused production rules to get rid of warnings
       which crept in on the last commit.
      Fix up tabbing in some places by removing embedded spaces.
      30ab107d
    • Thomas G. Lockhart's avatar
      Support SQL99 embedded double-quote syntax for quoted identifiers. · df402346
      Thomas G. Lockhart authored
      Allow this in the parser and in pg_dump, but it is probably not enough
       for a complete solution.
      Better to have the feature started then never here.
      df402346
    • Tom Lane's avatar
      Toast all the system-table columns that seem to need it. It turns out · c3e2a951
      Tom Lane authored
      that giving pg_proc a toast table required solving the same problems
      we'd have to solve for pg_class --- pg_proc is one of the relations
      that gets bootstrapped in relcache.c.  Solution is to go back at the
      end of initialization and read in the *real* pg_class row to replace
      the phony entry created by formrdesc().  This should work as long as
      there's no need to touch any toasted values during initialization,
      which seems a reasonable assumption.
      Although I did not add a toast-table for every single system table
      with a varlena attribute, I believe that it would work to just do
      ALTER TABLE pg_class CREATE TOAST TABLE.  So anyone who's really
      intent on having several thousand ACL entries for a rel could do it.
      NOTE: I didn't force initdb, but you must do one to see the effects
      of this patch.
      c3e2a951
    • Tom Lane's avatar
      Clean up inefficiency in ExecRelCheck, and cause it to do the right · 8ae23135
      Tom Lane authored
      thing when there are multiple result relations.  Formerly, during
      something like 'UPDATE foo*', foo's constraints and *only* foo's
      constraints would be applied to all foo's children.  Wrong-o ...
      8ae23135
    • Tom Lane's avatar
      Ensure that catcache 'busy' flags are reset at transaction abort. · 925418d2
      Tom Lane authored
      Without this, an elog during cache-entry load leaves that catcache
      unusable.  elog in that segment of code is pretty unusual but it can
      happen.
      925418d2
    • Tom Lane's avatar
      Copy sub-Query nodes to avoid trouble when same sub-Query is linked to · 465a3b0a
      Tom Lane authored
      multiple times in the parsetree (can happen in COALESCE or BETWEEN
      contexts, for example).  This is a pretty grotty solution --- it will
      do for now, but perhaps we can do better when we redesign querytrees.
      What we need is a consistent policy about whether querytrees should be
      considered read-only structures or not ...
      465a3b0a
  11. 05 Aug, 2000 3 commits
  12. 04 Aug, 2000 5 commits
    • Bruce Momjian's avatar
      Back out to_ascii patch from Karel. · 129f1a31
      Bruce Momjian authored
      129f1a31
    • Bruce Momjian's avatar
      403e522f
    • Bruce Momjian's avatar
      to_ascii( text ) · 317ff59c
      Bruce Momjian authored
              - encode 'text' from database encoding to ASCII
      
              to_ascii('\256\341k')
      
      
       to_ascii( text, int4 )
      
              - encode 'text' from 'int4' encoding to ASCII
      
                to_ascii('\256\341k', 8)
      
      
       to_ascii( text, name )
      
              - encode 'text' from 'name' encoding to ASCII
      
                to_ascii('\256\341k', 'LATIN2')
      
      
        Now is supported LATIN1, LATIN2, WIN1250. For other character sets I
      haven't good resources. Add new encoding is easy...
      
       If encoding is not supported returns ERROR.
      
       Note --- not exists total corect conversion to ASCII, this function try
              convert chars those is _probably_ interpret-able in ASCII for
              others use ' '. But for example for all Czech characters it is
              sufficient ... hmm Chinese / JAP and other complicated langs
      have
              bad luck here :-(
      
                                                      Karel
      317ff59c
    • Hiroshi Inoue's avatar
      a1464e97
    • Tom Lane's avatar
      Fix tuptoaster bugs induced by making bytea toastable. Durn thing was · dd8ad641
      Tom Lane authored
      trying to toast tuples inserted into toast tables!  Fix is two-pronged:
      first, ensure all columns of a toast table are marked attstorage='p',
      and second, alter the target chunk size so that it's less than the
      threshold for trying to toast a tuple.  (Code tried to do that but the
      expression was wrong.)  A few cosmetic cleanups in tuptoaster too.
      NOTE: initdb forced due to change in toaster chunk-size.
      dd8ad641