summaryrefslogtreecommitdiff
path: root/src
AgeCommit message (Collapse)Author
2001-09-20Remove some dead code and obsolete, misleading comments.Tom Lane
2001-09-20Provide tunable knob for x = NULL -> x IS NULL transformation, default to off.Peter Eisentraut
2001-09-19Remove old file.Peter Eisentraut
2001-09-19Change the version. We are moving towards the next release.D'Arcy J.M. Cain
Fixed a nasty bug that messed up negative money amounts.
2001-09-19Avoid unnecessary strcasecmp -- replace by strcmp. Fixes reported bugPeter Eisentraut
that made setting serializable isolation level impossible in Turkish locale.
2001-09-19- Synced preproc.y with gram.y.Michael Meskes
- Synced pgc.l with scan.l. - Synced keyword.c. - Include the remaining patches by Christof Petig <christof.petig@wtal.de>.
2001-09-19Replace useless strcasecmp's by strcmp's.Peter Eisentraut
2001-09-18EXPLAIN ANALYZE feature to measure and show actual runtimes and tupleTom Lane
counts alongside the planner's estimates. By Martijn van Oosterhout, with some further work by Tom Lane.
2001-09-17Unify the zip rules and variables.Peter Eisentraut
2001-09-17Fix bogus failure-return value from lo_create, per report from GavinTom Lane
Sherry. Also clean up leakage of open files and LOs in failure exits from lo_import and lo_export.
2001-09-17Attached is a patch that fixes ResultSetMetaData.isNullable() inBruce Momjian
the JDBC driver. This method is currently unimplemented and always returns ResultSetMetaData.columnNullable. This is obviously incorrect when a column is defined with NOT NULL or PRIMARY KEY. And we have to think of check constraints, views, functions etc. The patch simply changes the return value to ResultSetMetaData.columnNullableUnknown. This is until someone comes up with a real implementation of course. On Fri, 14 Sep 2001 17:53:50 +0200, Tomisaw Kity?ski wrote: >Hello there, > >could someone tell me, please, do I have any chance to get >proper implementation of above method in JDBC (1.1+) soon? > >Current "return 1" works fine on most tables, however it seems >to be a little bit incorrect with some of them ;) Ren? Pijlman
2001-09-17I'm attaching a patch which fixes the corruption in strings causedBruce Momjian
by escape processing in the SQL statement. I've tested this for a while now and it appears to work well. Previously string data with {d was getting corrupt as the {d was being stripped regardless of whether it was an escape code or not. I also added checking for time and timestamp escape processing strings as per 11.3 in the specification. The patch is against the latest CVS. Thomas O'Dowd
2001-09-17Change FixupBlobXrefs() to take 'lo' type into account.Hiroshi Inoue
2001-09-17Simplify and clean up FigureColname; make it work without coredumpingTom Lane
for TypeCast case.
2001-09-17Use portable putenv(), not unportable setenv().Tom Lane
2001-09-17Suppress compiler warning.Tom Lane
2001-09-16Russian translation from Serguei MokhovPeter Eisentraut
2001-09-16Update from Serguei MokhovPeter Eisentraut
2001-09-16Install dynamically loadable modules into a private subdirectoryPeter Eisentraut
under libdir, for a cleaner separation in the installation layout and compatibility with binary packaging standards. Point backend's default search location there. The contrib modules are also installed in the said location, giving them the benefit of the default search path as well. No changes in user interface nevertheless.
2001-09-14> Here's a revised patch. Changes:Bruce Momjian
> > 1. Now outputs '\\' instead of '\134' when using encode(bytea, 'escape') > Note that I ended up leaving \0 as \000 so that there are no ambiguities > when decoding something like, for example, \0123. > > 2. Fixed bug in byteain which allowed input values which were not valid > octals (e.g. \789), to be parsed as if they were octals. > > Joe > Here's rev 2 of the bytea string support patch. Changes: 1. Added missing declaration for MatchBytea function 2. Added PQescapeBytea to fe-exec.c 3. Applies cleanly on cvs tip from this afternoon I'm hoping that someone can review/approve/apply this before beta starts, so I guess I'd vote (not that it counts for much) to delay beta a few days :-) Joe Conway
2001-09-14Allow '1' in jdbc2 boolean test.Bruce Momjian
2001-09-14Remove --enable-unicode-conversionTatsuo Ishii
unicode-conversion is always on if --enable-multibyte is specified Tatsuo Ishii
2001-09-14Change an *if condition*.Hiroshi Inoue
Hiroshi Inoue
2001-09-141) Improve the implementation of *Disallow Premature* forHiroshi Inoue
older versions of servers. 2) Implement SQLProcedures. Hiroshi Inoue
2001-09-14Fix a coversation error with pre 6.4 versions.Hiroshi Inoue
Hiroshi Inoue
2001-09-13Add missing paren to ODBC compiles.Bruce Momjian
2001-09-13Didn't want that jdbc patch in there yet.Bruce Momjian
2001-09-13> I found a problem with PQescapeString (I think). Since it escapesBruce Momjian
> null bytes to be literally '\0', the following can happen: > 1. User inputs string value as "<null byte>##" where ## are digits in the > range of 0 to 7. > 2. PQescapeString converts this to "\0##" > 3. Escaped string is used in a context that causes "\0##" to be evaluated as > an octal escape sequence. I agree that this is a problem, though it is not possible to do anything harmful with it. In addition, it only occurs if there are any NUL characters in its input, which is very unlikely if you are using C strings. The patch below addresses the issue by removing escaping of \0 characters entirely. > If the goal is to "safely" encode null bytes, and preserve the rest of the > string as it was entered, I think the null bytes should be escaped as \\000 > (note that if you simply use \000 the same string truncation problem > occurs). We can't do that, this would require 4n + 1 bytes of storage for the result, breaking the interface. Florian Weimer
2001-09-131) Not export ODBC 3.0 functions.Hiroshi Inoue
2) (Maybe) fix a bug reported by Mika Muntila.
2001-09-12max_locks_per_transaction seems to be a more consistent name thanPeter Eisentraut
max_locks_per_xact.
2001-09-12It is not fixed and I doubt that it is working fine in current CVS. TheBruce Momjian
bugfix is in the attached patch. Please apply it. Thanks. Output must be: test=# SELECT to_char(485, 'RN'); to_char ----------------- CDLXXXV (1 row) test=# SELECT to_char(485, 'FMRN'); to_char --------- CDLXXXV (1 row) test=# SELECT to_char(1000, 'RN'); to_char ----------------- M (1 row) test=# SELECT to_char(7.2, '"Welcome to"9.9 "release! :-)"'); to_char ----------------------------- Welcome to 7.2 release! :-) (1 row) Karel Zak
2001-09-12I noticed that plpython does not make the relid available insideBruce Momjian
a trigger the way that pltcl does. Here's a little patch that adds it in. -Brad McLean
2001-09-11Link ODBC driver with -lnsl and -lsocket, for Solaris.Peter Eisentraut
reported by Bob Deblier (bob@virtualunlimited.com)
2001-09-11Use gcc -shared rather than gcc -G for shared library linking on Solaris.Peter Eisentraut
suggested by Bob Deblier (bob@virtualunlimited.com)
2001-09-11Invoke on_exit() with correct number and type of arguments.Peter Eisentraut
2001-09-11Fix some multibyte related bugs.Hiroshi Inoue
Psqlodbc is 7.01.0007 now. Hiroshi Inoue
2001-09-11Implement following item in TODO:Tatsuo Ishii
* Reject character sequences those are not valid in their charset
2001-09-11Implement following item in TODO:Tatsuo Ishii
* Reject character sequences those are not valid in their charset
2001-09-10Add explicit '-print' to 'find' commands.Peter Eisentraut
(partially) from Ian Lance Taylor
2001-09-10Remove extra space at end of line.Peter Eisentraut
2001-09-10Attached is a patch that fixes DatabaseMetaDataTest in the JDBCBruce Momjian
driver's test suite. With previous patches applied, this reduces the number of failures of the test suite from 6 to 4. The patch fixes the test case itself, rather than the driver. Details: 1) The driver correctly provided DatabaseMetaData about the sort order of NULLs. This was confirmed by Peter Eisentraut on pgsql-hackers. I fixed the test to accept/require the current behaviour, and made it dependent on the backend version. See nullsAreSortedAtStart(), nullsAreSortedAtEnd(), nullsAreSortedHigh() and nullsAreSortedLow(). 2) DatabaseMetaData.supportsOrderByUnrelated() correctly returned true (an ORDER BY clause can contain columns that are not in the SELECT clause), but the test case required false. Fixed that. 3) Replaced deprecated assert() of junit.framework.TestCase by assertEquals(), assertTrue() and assertNotNull(). This is because assert will be a new keyword in Java 1.4. 4) Replaced assert(message,false) by the more elegant fail(message). Regards, Ren? Pijlman <rene@lab.applinet.nl>
2001-09-10Attached is a patch to add bytea support to JDBC.Bruce Momjian
This patch does the following: - Adds binary datatype support (bytea) - Changes getXXXStream()/setXXXStream() methods to be spec compliant - Adds ability to revert to old behavior Details: Adds support for the binary type bytea. The ResultSet.getBytes() and PreparedStatement.setBytes() methods now work against columns of bytea type. This is a change in behavior from the previous code which assumed the column type was OID and thus a LargeObject. The new behavior is more complient with the JDBC spec as BLOB/CLOB are to be used for LargeObjects and the getBytes()/setBytes() methods are for the databases binary datatype (which is bytea in postgres). Changes the behavior of the getBinaryStream(), getAsciiStream(), getCharacterStream(), getUnicodeStream() and their setXXXStream() counterparts. These methos now work against either the bytea type (BinaryStream) or the text types (AsciiStream, CharacterStream, UnicodeStream). The previous behavior was that these all assumed the underlying column was of type OID and thus a LargeObject. The spec/javadoc for these methods indicate that they are for LONGVARCHAR and LONGVARBINARY datatypes, which are distinct from the BLOB/CLOB datatypes. Given that the bytea and text types support upto 1G, they are the LONGVARBINARY and LONGVARCHAR datatypes in postgres. Added support for turning off the above new functionality. Given that the changes above are not backwardly compatible (however they are more spec complient), I added the ability to revert back to the old behavior. The Connection now takes an optional parameter named 'compatible'. If the value of '7.1' is passed, the driver reverts to the 7.1 behavior. If the parameter is not passed or the value '7.2' is passed the behavior is the new behavior. The mechanism put in place can be used in the future when/if similar needs arise to change behavior. This is patterned after how Oracle does this (i.e. Oracle has a 'compatible' parameter that behaves in a similar manner). Misc fixes. Cleaned up a few things I encountered along the way. Note that in testing the patch I needed to ignore whitespace differences in order to get it to apply cleanly (i.e. patch -l -i byteapatch.diff). Also this patch introduces a new file (src/interfaces/jdbc/org/postgresql/util/PGbytea.java). Barry Lind
2001-09-10On Fri, 07 Sep 2001 01:34:46 -0400, Tom Lane wrote:Bruce Momjian
>there is still an unpatched reference to pg_description in >getColumns(), in both jdbc1 and jdbc2. This was introduced by Jeroen's patch (see http://fts.postgresql.org/db/mw/msg.html?mid=1032468). Attached is a patch that returns getColumns() to using "select obj_description()" instead of direct access to pg_description, as per the request by Tom. I've incorporated Jeroen's fix to left outer join with pg_attrdef instead of inner join, so getColumns() also returns columns without a default value. I have, however, not included Jeroen's attempt to combine multiple queries into one huge multi-join query for better performance, because: 1) I don't know how to do that using obj_description() instead of direct access to pg_description 2) I don't think a performance improvement (if any) in this method is very important Because of the outer join, getColumns() will only work with a backend >= 7.1. Since the conditional coding for 7.1/7.2 and jdbc1/jdbc2 is already giving me headaches I didn't pursue a pre-7.1 solution. Regards, Ren? Pijlman <rene@lab.applinet.nl>
2001-09-10Attached is a patch that fixesBruce Momjian
ConnectionTest.testTransactionIsolation() in the JDBC driver's test suite. This reduces the number of failures of the test suite from 7 to 6. The patch fixes the test case itself, rather than the driver. In addition to the change described in my posting below, I fixed the part of the test with autocommit enabled. The author of the test assumed that setting the transaction isolation level would have no effect, but in fact it does. Perhaps the test case worked with pre-7.1 behaviour, when the JDBC driver set the isolation level in every transaction, instead of using "set session characteristics". Anyway, now it works with a backend built from current CVS and the behaviour is JDBC compliant. I also extended the test case by changing the isolation level before beginning a transaction and verifying it inside the transaction. Regards, Ren? Pijlman
2001-09-10Bug #1: attribute name when column is type cast:Bruce Momjian
Given the following table: test=# \d f Table "f" Column | Type | Modifiers --------+---------+----------- i | integer | test | text | If I do the following: test=# insert into f values(1,'test'); INSERT 139549 1 test=# select i::int8,test from f; ?column? | test ----------+------ 1 | test (1 row) It doesn't make much sense that the first column should be called '?column?'. The patch results in the output appearing like this: test=# select i::int8,test from f; i | test ---+------ 1 | test (1 row) ---------- Gavin Sherry
2001-09-10> NOTE: in the command.c in three places there (I believe) is a typo:Bruce Momjian
> > "parse error at [the] end of line" > > Attached patch also fixes it. I noticed this while editing the po file. > If I'm wrong, please ignore the command.c.patch. I will revert my translation > as well then. > > -- > Serguei A. Mokhov
2001-09-10The attached patch should be sufficient to fix libpgtcl. It requiresBruce Momjian
PostgreSQL to support unicode-conversion, but retains binary compatibility among Tcl versions. However, it neither checks at compile time not at runtime, if support for unicode-conversion does really exist and it doesn't prevent the user from changing the client encoding after initialization. I think there should be warnings about this somewhere in the documentation. Reinhard Max
2001-09-10Change dialog windows.Hiroshi Inoue
2001-09-101) Fix SQLForeignKeys() in multibyte mode.Hiroshi Inoue
2) Fix a bug with NUMERIC scale in case of Parse statement option. 3) Remove a no longer needed loop in CC_send_query(). Hiroshi Inoue
2001-09-10Remove INV_ARCHIVE mention in python readme.Bruce Momjian