- 14 Mar, 2000 10 commits
- 
- 
Thomas G. Lockhart authoredImplement TIME WITH TIME ZONE type (timetz internal type). Remap length() for character strings to CHAR_LENGTH() for SQL92 and to remove the ambiguity with geometric length() functions. Keep length() for character strings for backward compatibility. Shrink stored views by removing internal column name list from visible rte. Implement min(), max() for time and timetz data types. Implement conversion of TIME to INTERVAL. Implement abs(), mod(), fac() for the int8 data type. Rename some math functions to generic names: round(), sqrt(), cbrt(), pow(), etc. Rename NUMERIC power() function to pow(). Fix int2 factorial to calculate result in int4. Enhance the Oracle compatibility function translate() to work with string arguments (from Edwin Ramirez). Modify pg_proc system table to remove OID holes. 
- 
Thomas G. Lockhart authored
- 
Tom Lane authoredof BufferLocks[] entry just once. Seems to save 10% or so of the routine's runtime, which'd not be worth worrying about if it weren't such a hotspot. 
- 
Bruce Momjian authoredPlease > apply the attached patch to > > backend/port/qnx4 > > Andreas Kardos > 
- 
Bruce Momjian authoredalpha_cc > template file. Patch attached. > > Andreas Kardos > 
- 
Bruce Momjian authored(Alpha). > > Andreas Kardos 
- 
Bruce Momjian authored(Alpha). > 
- 
Bruce Momjian authoredPlease > apply the attached patch. > > Andreas Kardos > > 
- 
Tatsuo Ishii authoredchecking postmaster.pid. It's not enough to check the existence of postmaster.pid since DB recovery might be running. 
- 
Tom Lane authoredof tuples we are going to retrieve from a sub-SELECT. Must have been half asleep when I did this code the first time :-( 
 
- 
- 13 Mar, 2000 4 commits
- 
- 
Peter Eisentraut authoredpsql script would be dropped silently. 
- 
Tom Lane authored(ie, allow rounding to occur at a digit position left of the decimal point). Apparently this is how Oracle handles it, and there are precedents in other programming languages as well. 
- 
Tom Lane authoredSince we detect oversize tuples elsewhere, I see no reason not to allow string constants that are 'too long' --- after all, they might never get stored in a tuple at all. 
- 
Tom Lane authoredYY_READ_BUF_SIZE, which turns out to have nothing to do with buffer size. It's just a totally arbitrary upper limit on how much data myinput() is asked for at one time. 
 
- 
- 12 Mar, 2000 4 commits
- 
- 
Tom Lane authoredset of SQL-standard type names that we accept. 
- 
Tom Lane authoredthat the inputs to a given operator can be recursively simplified to constants, it was evaluating the operator using the op's *original* (unsimplified) arg list, so that any subexpressions had to be evaluated again. A constant subexpression at depth N got evaluated N times. Probably not very important in practical situations, but it made us look real slow in MySQL's 'crashme' test... 
- 
Tom Lane authoredfireRIRonSubselect was invoked twice at each subselect, leading to an exponential amount of wasted effort. 
- 
Tom Lane authoredgone, replaced by plain a_expr. The few places where we needed to distinguish NULL from a_expr are now handled by tests inside the actions rather than by separate productions. This allows us to accept queries like 'SELECT 1 + NULL' without requiring parentheses around the NULL. 
 
- 
- 11 Mar, 2000 9 commits
- 
- 
Tom Lane authoredsubplan: do it if subplan has subplans itself, and always do it if the subplan is an indexscan. (I originally set it to materialize an indexscan only if the indexqual is fairly selective, but I dunno what I was thinking ... an unselective indexscan is still expensive ...) 
- 
Tom Lane authoredcategory STRING. Also, if UNKNOWNOID is passed in, return UNKNOWN_TYPE not USER_TYPE. 
- 
Tom Lane authoredcoercion code. I'm beginning to wonder why we have separate candidate selection routines for functions, operators, and aggregates --- shouldn't this code all be unified? But meanwhile, SELECT 'a' LIKE 'a'; finally works; the code for dealing with unknown input types for operators was pretty busted. 
- 
Peter Eisentraut authored
- 
Tom Lane authoredsubPlans to be considered 'simple'. This fixes reported problem with 'return exists (select 1 from foo);' in plpgsql function. 
- 
Tom Lane authoredper pghackers discussion around 20-Feb. Also add specific error messages for unterminated comments and unterminated quoted strings. These things are nonissues for input coming from psql, but they do matter for input coming from other front ends. 
- 
Tom Lane authoredabout thread-safeness of the library. 
- 
Tom Lane authoredarray. This allows processing of conninfo strings to be made thread-safe, at the cost of a small memory leak in applications that use PQconndefaults() and are not updated to free the returned array via the new PQconninfoFree() function. But PQconndefaults() is probably not used very much, so this seems like a good compromise. 
- 
Tom Lane authorederror message. 
 
- 
- 10 Mar, 2000 3 commits
- 
- 
Peter Eisentraut authored
- 
Marc G. Fournier authoredmake sure that cvslog is workign right ... no changes but to remove a blank line 
- 
Michael Meskes authored
 
- 
- 09 Mar, 2000 7 commits
- 
- 
Bruce Momjian authored
- 
Bruce Momjian authored
- 
Bruce Momjian authored
- 
Peter Eisentraut authoredSome corrections in installation procedure 
- 
Michael Meskes authored
- 
Tom Lane authorednodes. The former version failed to check permissions of relations that were referenced in second and later clauses of UNIONs, and it did not check permissions of tables referenced via inheritance. 
- 
Hiroshi Inoue authoredThey are #ifdef'd. Add -D_DROP_COLUMN_HACK__ compile option to evaluate it. 
 
- 
- 08 Mar, 2000 3 commits