123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801 |
- #
- # Run this script to generated a changes.html output file
- #
- puts {<html>
- <head>
- <title>SQLite Change Log</title>
- </head>
- <body bgcolor="white">
- <h1 align="center">Recent Changes To SQLite</h1>
- <p>
- This file provides a high-level summary of changes to SQLite.
- For more detail, refer the the checkin logs generated by
- CVS at
- <a href="http://cvs.hwaci.com:2080/sqlite/timeline">
- http://cvs.hwaci.com:2080/sqlite/timeline</a>.
- </p>
- <DL>
- }
- proc chng {date desc} {
- puts "<DT><B>$date</B></DT>"
- puts "<DD><P><UL>$desc</UL></P></DD>"
- }
- chng {2002 Jun 17 (2.5.0)} {
- <li>Added support for row triggers.</li>
- <li>Added SQL-92 compliant handling of NULLs.</li>
- <li>Add support for the full SQL-92 join syntax and LEFT OUTER JOINs.</li>
- <li>Double-quoted strings interpreted as column names not text literals.</li>
- <li>Parse (but do not implement) foreign keys.</li>
- <li>Performance improvemenets in the parser, pager, and WHERE clause code
- generator.</li>
- <li>Make the LIMIT clause work on subqueries. (ORDER BY still does not
- work, though.)</li>
- <li>Added the "%Q" expansion to sqlite_*_printf().</li>
- <li>Bug fixes too numerious to mention (see the change log).</li>
- }
- chng {2002 May 09 (2.4.12)} {
- <li>Added logic to detect when the library API routines are called out
- of sequence.</li>
- }
- chng {2002 May 08 (2.4.11)} {
- <li>Bug fix: Column names in the result set were not being generated
- correctly for some (rather complex) VIEWs. This could cause a
- segfault under certain circumstances.</li>
- }
- chng {2002 May 02 (2.4.10)} {
- <li>Bug fix: Generate correct column headers when a compound SELECT is used
- as a subquery.</li>
- <li>Added the sqlite_encode_binary() and sqlite_decode_binary() functions to
- the source tree. But they are not yet linked into the library.</li>
- <li>Documentation updates.</li>
- <li>Export the sqlite_changes() function from windows DLLs.</li>
- <li>Bug fix: Do not attempt the subquery flattening optimization on queries
- that lack a FROM clause. To do so causes a segfault.</li>
- }
- chng {2002 Apr 21 (2.4.9)} {
- <li>Fix a bug that was causing the precompiled binary of SQLITE.EXE to
- report "out of memory" under Windows 98.</li>
- }
- chng {2002 Apr 20 (2.4.8)} {
- <li>Make sure VIEWs are created after their corresponding TABLEs in the
- output of the <b>.dump</b> command in the shell.</li>
- <li>Speed improvements: Do not do synchronous updates on TEMP tables.</li>
- <li>Many improvements and enhancements to the shell.</li>
- <li>Make the GLOB and LIKE operators functions that can be overridden
- by a programmer. This allows, for example, the LIKE operator to
- be changed to be case sensitive.</li>
- }
- chng {2002 Apr 06 (2.4.7)} {
- <li>Add the ability to put TABLE.* in the column list of a
- SELECT statement.</li>
- <li>Permit SELECT statements without a FROM clause.</li>
- <li>Added the <b>last_insert_rowid()</b> SQL function.</li>
- <li>Do not count rows where the IGNORE conflict resultion occurs in
- the row count.</li>
- <li>Make sure functions expressions in the VALUES clause of an INSERT
- are correct.</li>
- <li>Added the <b>sqlite_changes()</b> API function to return the number
- of row that changed in the most recent operation.</li>
- }
- chng {2002 Apr 02 (2.4.6)} {
- <li>Bug fix: Correctly handle terms in the WHERE clause of a join that
- do not contain a comparison operator.</li>
- }
- chng {2002 Apr 01 (2.4.5)} {
- <li>Bug fix: Correctly handle functions that appear in the WHERE clause
- of a join.</li>
- <li>When the PRAGMA vdbe_trace=ON is set, correctly print the P3 operand
- value when it is a pointer to a structure rather than a pointer to
- a string.</li>
- <li>When inserting an explicit NULL into an INTEGER PRIMARY KEY, convert
- the NULL value into a unique key automatically.</li>
- }
- chng {2002 Mar 24 (2.4.4)} {
- <li>Allow "VIEW" to be a column name</li>
- <li>Added support for CASE expressions (patch from Dan Kennedy)</li>
- <li>Added RPMS to the delivery (patches from Doug Henry)</li>
- <li>Fix typos in the documentation</li>
- <li>Cut over configuration management to a new CVS repository with
- its own CVSTrac bug tracking system.</li>
- }
- chng {2002 Mar 22 (2.4.3)} {
- <li>Fix a bug in SELECT that occurs when a compound SELECT is used as a
- subquery in the FROM of a SELECT.</li>
- <li>The <b>sqlite_get_table()</b> function now returns an error if you
- give it two or more SELECTs that return different numbers of columns.</li>
- }
- chng {2002 Mar 14 (2.4.2)} {
- <li>Bug fix: Fix an assertion failure that occurred when ROWID was a column
- in a SELECT statement on a view.</li>
- <li>Bug fix: Fix an uninitialized variable in the VDBE that would could an
- assert failure.</li>
- <li>Make the os.h header file more robust in detecting when the compile is
- for windows and when it is for unix.</li>
- }
- chng {2002 Mar 13 (2.4.1)} {
- <li>Using an unnamed subquery in a FROM clause would cause a segfault.</li>
- <li>The parser now insists on seeing a semicolon or the end of input before
- executing a statement. This avoids an accidental disaster if the
- WHERE keyword is misspelled in an UPDATE or DELETE statement.</li>
- }
- chng {2002 Mar 10 (2.4.0)} {
- <li>Change the name of the sanity_check PRAGMA to <b>integrity_check</b>
- and make it available in all compiles.</li>
- <li>SELECT min() or max() of an indexed column with no WHERE or GROUP BY
- clause is handled as a special case which avoids a complete table scan.</li>
- <li>Automatically generated ROWIDs are now sequential.</li>
- <li>Do not allow dot-commands of the command-line shell to occur in the
- middle of a real SQL command.</li>
- <li>Modifications to the "lemon" parser generator so that the parser tables
- are 4 times smaller.</li>
- <li>Added support for user-defined functions implemented in C.</li>
- <li>Added support for new functions: <b>coalesce()</b>, <b>lower()</b>,
- <b>upper()</b>, and <b>random()</b>
- <li>Added support for VIEWs.</li>
- <li>Added the subquery flattening optimizer.</li>
- <li>Modified the B-Tree and Pager modules so that disk pages that do not
- contain real data (free pages) are not journalled and are not
- written from memory back to the disk when they change. This does not
- impact database integrity, since the
- pages contain no real data, but it does make large INSERT operations
- about 2.5 times faster and large DELETEs about 5 times faster.</li>
- <li>Made the CACHE_SIZE pragma persistent</li>
- <li>Added the SYNCHRONOUS pragma</li>
- <li>Fixed a bug that was causing updates to fail inside of transactions when
- the database contained a temporary table.</li>
- }
- chng {2002 Feb 18 (2.3.3)} {
- <li>Allow identifiers to be quoted in square brackets, for compatibility
- with MS-Access.</li>
- <li>Added support for sub-queries in the FROM clause of a SELECT.</li>
- <li>More efficient implementation of sqliteFileExists() under Windows.
- (by Joel Luscy)</li>
- <li>The VALUES clause of an INSERT can now contain expressions, including
- scalar SELECT clauses.</li>
- <li>Added support for CREATE TABLE AS SELECT</li>
- <li>Bug fix: Creating and dropping a table all within a single
- transaction was not working.</li>
- }
- chng {2002 Feb 14 (2.3.2)} {
- <li>Bug fix: There was an incorrect assert() in pager.c. The real code was
- all correct (as far as is known) so everything should work OK if you
- compile with -DNDEBUG=1. When asserts are not disabled, there
- could be a fault.</li>
- }
- chng {2002 Feb 13 (2.3.1)} {
- <li>Bug fix: An assertion was failing if "PRAGMA full_column_names=ON;" was
- set and you did a query that used a rowid, like this:
- "SELECT rowid, * FROM ...".</li>
- }
- chng {2002 Jan 30 (2.3.0)} {
- <li>Fix a serious bug in the INSERT command which was causing data to go
- into the wrong columns if the data source was a SELECT and the INSERT
- clauses specified its columns in some order other than the default.</li>
- <li>Added the ability to resolve constraint conflicts is ways other than
- an abort and rollback. See the documentation on the "ON CONFLICT"
- clause for details.</li>
- <li>Temporary files are now automatically deleted by the operating system
- when closed. There are no more dangling temporary files on a program
- crash. (If the OS crashes, fsck will delete the file after reboot
- under Unix. I do not know what happens under Windows.)</li>
- <li>NOT NULL constraints are honored.</li>
- <li>The COPY command puts NULLs in columns whose data is '\N'.</li>
- <li>In the COPY command, backslash can now be used to escape a newline.</li>
- <li>Added the SANITY_CHECK pragma.</li>
- }
- chng {2002 Jan 28 (2.2.5)} {
- <li>Important bug fix: the IN operator was not working if either the
- left-hand or right-hand side was derived from an INTEGER PRIMARY KEY.</li>
- <li>Do not escape the backslash '\' character in the output of the
- <b>sqlite</b> command-line access program.</li>
- }
- chng {2002 Jan 22 (2.2.4)} {
- <li>The label to the right of an AS in the column list of a SELECT can now
- be used as part of an expression in the WHERE, ORDER BY, GROUP BY, and/or
- HAVING clauses.</li>
- <li>Fix a bug in the <b>-separator</b> command-line option to the <b>sqlite</b>
- command.</li>
- <li>Fix a problem with the sort order when comparing upper-case strings against
- characters greater than 'Z' but less than 'a'.</li>
- <li>Report an error if an ORDER BY or GROUP BY expression is constant.</li>
- }
- chng {2002 Jan 16 (2.2.3)} {
- <li>Fix warning messages in VC++ 7.0. (Patches from nicolas352001)</li>
- <li>Make the library thread-safe. (The code is there and appears to work
- but has not been stressed.)</li>
- <li>Added the new <b>sqlite_last_insert_rowid()</b> API function.</li>
- }
- chng {2002 Jan 13 (2.2.2)} {
- <li>Bug fix: An assertion was failing when a temporary table with an index
- had the same name as a permanent table created by a separate process.</li>
- <li>Bug fix: Updates to tables containing an INTEGER PRIMARY KEY and an
- index could fail.</li>
- }
- chng {2002 Jan 9 (2.2.1)} {
- <li>Bug fix: An attempt to delete a single row of a table with a WHERE
- clause of "ROWID=x" when no such rowid exists was causing an error.</li>
- <li>Bug fix: Passing in a NULL as the 3rd parameter to <b>sqlite_open()</b>
- would sometimes cause a coredump.</li>
- <li>Bug fix: DROP TABLE followed by a CREATE TABLE with the same name all
- within a single transaction was causing a coredump.</li>
- <li>Makefile updates from A. Rottmann</li>
- }
- chng {2001 Dec 22 (2.2.0)} {
- <li>Columns of type INTEGER PRIMARY KEY are actually used as the primary
- key in underlying B-Tree representation of the table.</li>
- <li>Several obscure, unrelated bugs were found and fixed while
- implemented the integer primary key change of the previous bullet.</li>
- <li>Added the ability to specify "*" as part of a larger column list in
- the result section of a SELECT statement. For example:
- <nobr>"<b>SELECT rowid, * FROM table1;</b>"</nobr>.</li>
- <li>Updates to comments and documentation.</li>
- }
- chng {2001 Dec 14 (2.1.7)} {
- <li>Fix a bug in <b>CREATE TEMPORARY TABLE</b> which was causing the
- table to be initially allocated in the main database file instead
- of in the separate temporary file. This bug could cause the library
- to suffer an assertion failure and it could cause "page leaks" in the
- main database file.
- <li>Fix a bug in the b-tree subsystem that could sometimes cause the first
- row of a table to be repeated during a database scan.</li>
- }
- chng {2001 Dec 14 (2.1.6)} {
- <li>Fix the locking mechanism yet again to prevent
- <b>sqlite_exec()</b> from returning SQLITE_PROTOCOL
- unnecessarily. This time the bug was a race condition in
- the locking code. This change effects both POSIX and Windows users.</li>
- }
- chng {2001 Dec 6 (2.1.5)} {
- <li>Fix for another problem (unrelated to the one fixed in 2.1.4)
- that sometimes causes <b>sqlite_exec()</b> to return SQLITE_PROTOCOL
- unnecessarily. This time the bug was
- in the POSIX locking code and should not effect windows users.</li>
- }
- chng {2001 Dec 4 (2.1.4)} {
- <li>Sometimes <b>sqlite_exec()</b> would return SQLITE_PROTOCOL when it
- should have returned SQLITE_BUSY.</li>
- <li>The fix to the previous bug uncovered a deadlock which was also
- fixed.</li>
- <li>Add the ability to put a single .command in the second argument
- of the sqlite shell</li>
- <li>Updates to the FAQ</li>
- }
- chng {2001 Nov 23 (2.1.3)} {
- <li>Fix the behavior of comparison operators
- (ex: "<b><</b>", "<b>==</b>", etc.)
- so that they are consistent with the order of entries in an index.</li>
- <li>Correct handling of integers in SQL expressions that are larger than
- what can be represented by the machine integer.</li>
- }
- chng {2001 Nov 22 (2.1.2)} {
- <li>Changes to support 64-bit architectures.</li>
- <li>Fix a bug in the locking protocol.</li>
- <li>Fix a bug that could (rarely) cause the database to become
- unreadable after a DROP TABLE due to corruption to the SQLITE_MASTER
- table.</li>
- <li>Change the code so that version 2.1.1 databases that were rendered
- unreadable by the above bug can be read by this version of
- the library even though the SQLITE_MASTER table is (slightly)
- corrupted.</li>
- }
- chng {2001 Nov 13 (2.1.1)} {
- <li>Bug fix: Sometimes arbirary strings were passed to the callback
- function when the actual value of a column was NULL.</li>
- }
- chng {2001 Nov 12 (2.1.0)} {
- <li>Change the format of data records so that records up to 16MB in size
- can be stored.</li>
- <li>Change the format of indices to allow for better query optimization.</li>
- <li>Implement the "LIMIT ... OFFSET ..." clause on SELECT statements.</li>
- }
- chng {2001 Nov 3 (2.0.8)} {
- <li>Made selected parameters in API functions <b>const</b>. This should
- be fully backwards compatible.</li>
- <li>Documentation updates</li>
- <li>Simplify the design of the VDBE by restricting the number of sorters
- and lists to 1.
- In practice, no more than one sorter and one list was ever used anyhow.
- </li>
- }
- chng {2001 Oct 21 (2.0.7)} {
- <li>Any UTF-8 character or ISO8859 character can be used as part of
- an identifier.</li>
- <li>Patches from Christian Werner to improve ODBC compatibility and to
- fix a bug in the round() function.</li>
- <li>Plug some memory leaks that use to occur if malloc() failed.
- We have been and continue to be memory leak free as long as
- malloc() works.</li>
- <li>Changes to some test scripts so that they work on Windows in
- addition to Unix.</li>
- }
- chng {2001 Oct 19 (2.0.6)} {
- <li>Added the EMPTY_RESULT_CALLBACKS pragma</li>
- <li>Support for UTF-8 and ISO8859 characters in column and table names.</li>
- <li>Bug fix: Compute correct table names with the FULL_COLUMN_NAMES pragma
- is turned on.</li>
- }
- chng {2001 Oct 14 (2.0.5)} {
- <li>Added the COUNT_CHANGES pragma.</li>
- <li>Changes to the FULL_COLUMN_NAMES pragma to help out the ODBC driver.</li>
- <li>Bug fix: "SELECT count(*)" was returning NULL for empty tables.
- Now it returns 0.</li>
- }
- chng {2001 Oct 13 (2.0.4)} {
- <li>Bug fix: an abscure and relatively harmless bug was causing one of
- the tests to fail when gcc optimizations are turned on. This release
- fixes the problem.</li>
- }
- chng {2001 Oct 13 (2.0.3)} {
- <li>Bug fix: the <b>sqlite_busy_timeout()</b> function was delaying 1000
- times too long before failing.</li>
- <li>Bug fix: an assertion was failing if the disk holding the database
- file became full or stopped accepting writes for some other reason.
- New tests were added to detect similar problems in the future.</li>
- <li>Added new operators: <b>&</b> (bitwise-and)
- <b>|</b> (bitwise-or), <b>~</b> (ones-complement),
- <b><<</b> (shift left), <b>>></b> (shift right).</li>
- <li>Added new functions: <b>round()</b> and <b>abs()</b>.</li>
- }
- chng {2001 Oct 9 (2.0.2)} {
- <li>Fix two bugs in the locking protocol. (One was masking the other.)</li>
- <li>Removed some unused "#include <unistd.h>" that were causing problems
- for VC++.</li>
- <li>Fixed <b>sqlite.h</b> so that it is usable from C++</li>
- <li>Added the FULL_COLUMN_NAMES pragma. When set to "ON", the names of
- columns are reported back as TABLE.COLUMN instead of just COLUMN.</li>
- <li>Added the TABLE_INFO() and INDEX_INFO() pragmas to help support the
- ODBC interface.</li>
- <li>Added support for TEMPORARY tables and indices.</li>
- }
- chng {2001 Oct 2 (2.0.1)} {
- <li>Remove some C++ style comments from btree.c so that it will compile
- using compilers other than gcc.</li>
- <li>The ".dump" output from the shell does not work if there are embedded
- newlines anywhere in the data. This is an old bug that was carried
- forward from version 1.0. To fix it, the ".dump" output no longer
- uses the COPY command. It instead generates INSERT statements.</li>
- <li>Extend the expression syntax to support "expr NOT NULL" (with a
- space between the "NOT" and the "NULL") in addition to "expr NOTNULL"
- (with no space).</li>
- }
- chng {2001 Sep 28 (2.0.0)} {
- <li>Automatically build binaries for Linux and Windows and put them on
- the website.</li>
- }
- chng {2001 Sep 28 (2.0-alpha-4)} {
- <li>Incorporate makefile patches form A. Rottmann to use LIBTOOL</li>
- }
- chng {2001 Sep 27 (2.0-alpha-3)} {
- <li>SQLite now honors the UNIQUE keyword in CREATE UNIQUE INDEX. Primary
- keys are required to be unique.</li>
- <li>File format changed back to what it was for alpha-1</li>
- <li>Fixes to the rollback and locking behavior</li>
- }
- chng {2001 Sep 20 (2.0-alpha-2)} {
- <li>Initial release of version 2.0. The idea of renaming the library
- to "SQLus" was abandoned in favor of keeping the "SQLite" name and
- bumping the major version number.</li>
- <li>The pager and btree subsystems added back. They are now the only
- available backend.</li>
- <li>The Dbbe abstraction and the GDBM and memory drivers were removed.</li>
- <li>Copyright on all code was disclaimed. The library is now in the
- public domain.</li>
- }
- chng {2001 Jul 23 (1.0.32)} {
- <li>Pager and btree subsystems removed. These will be used in a follow-on
- SQL server library named "SQLus".</li>
- <li>Add the ability to use quoted strings as table and column names in
- expressions.</li>
- }
- chng {2001 Apr 14 (1.0.31)} {
- <li>Pager subsystem added but not yet used.</li>
- <li>More robust handling of out-of-memory errors.</li>
- <li>New tests added to the test suite.</li>
- }
- chng {2001 Apr 6 (1.0.30)} {
- <li>Remove the <b>sqlite_encoding</b> TCL variable that was introduced
- in the previous version.</li>
- <li>Add options <b>-encoding</b> and <b>-tcl-uses-utf</b> to the
- <b>sqlite</b> TCL command.</li>
- <li>Add tests to make sure that tclsqlite was compiled using Tcl header
- files and libraries that match.</li>
- }
- chng {2001 Apr 5 (1.0.29)} {
- <li>The library now assumes data is stored as UTF-8 if the --enable-utf8
- option is given to configure. The default behavior is to assume
- iso8859-x, as it has always done. This only makes a difference for
- LIKE and GLOB operators and the LENGTH and SUBSTR functions.</li>
- <li>If the library is not configured for UTF-8 and the Tcl library
- is one of the newer ones that uses UTF-8 internally,
- then a conversion from UTF-8 to iso8859 and
- back again is done inside the TCL interface.</li>
- }
- chng {2001 Apr 4 (1.0.28)} {
- <li>Added limited support for transactions. At this point, transactions
- will do table locking on the GDBM backend. There is no support (yet)
- for rollback or atomic commit.</li>
- <li>Added special column names ROWID, OID, and _ROWID_ that refer to the
- unique random integer key associated with every row of every table.</li>
- <li>Additional tests added to the regression suite to cover the new ROWID
- feature and the TCL interface bugs mentioned below.</li>
- <li>Changes to the "lemon" parser generator to help it work better when
- compiled using MSVC.</li>
- <li>Bug fixes in the TCL interface identified by Oleg Oleinick.</li>
- }
- chng {2001 Mar 20 (1.0.27)} {
- <li>When doing DELETE and UPDATE, the library used to write the record
- numbers of records to be deleted or updated into a temporary file.
- This is changed so that the record numbers are held in memory.</li>
- <li>The DELETE command without a WHILE clause just removes the database
- files from the disk, rather than going through and deleting record
- by record.</li>
- }
- chng {2001 Mar 20 (1.0.26)} {
- <li>A serious bug fixed on Windows. Windows users should upgrade.
- No impact to Unix.</li>
- }
- chng {2001 Mar 15 (1.0.25)} {
- <li>Modify the test scripts to identify tests that depend on system
- load and processor speed and
- to warn the user that a failure of one of those (rare) tests does
- not necessarily mean the library is malfunctioning. No changes to
- code.
- </li>
- }
- chng {2001 Mar 14 (1.0.24)} {
- <li>Fix a bug which was causing
- the UPDATE command to fail on systems where "malloc(0)" returns
- NULL. The problem does not appear Windows, Linux, or HPUX but does
- cause the library to fail on QNX.
- </li>
- }
- chng {2001 Feb 19 (1.0.23)} {
- <li>An unrelated (and minor) bug from Mark Muranwski fixed. The algorithm
- for figuring out where to put temporary files for a "memory:" database
- was not working quite right.
- </li>
- }
- chng {2001 Feb 19 (1.0.22)} {
- <li>The previous fix was not quite right. This one seems to work better.
- </li>
- }
- chng {2001 Feb 19 (1.0.21)} {
- <li>The UPDATE statement was not working when the WHERE clause contained
- some terms that could be satisfied using indices and other terms that
- could not. Fixed.</li>
- }
- chng {2001 Feb 11 (1.0.20)} {
- <li>Merge development changes into the main trunk. Future work toward
- using a BTree file structure will use a separate CVS source tree. This
- CVS tree will continue to support the GDBM version of SQLite only.</li>
- }
- chng {2001 Feb 6 (1.0.19)} {
- <li>Fix a strange (but valid) C declaration that was causing problems
- for QNX. No logical changes.</li>
- }
- chng {2001 Jan 4 (1.0.18)} {
- <li>Print the offending SQL statement when an error occurs.</li>
- <li>Do not require commas between constraints in CREATE TABLE statements.</li>
- <li>Added the "-echo" option to the shell.</li>
- <li>Changes to comments.</li>
- }
- chng {2000 Dec 10 (1.0.17)} {
- <li>Rewrote <b>sqlite_complete()</b> to make it faster.</li>
- <li>Minor tweaks to other code to make it run a little faster.</li>
- <li>Added new tests for <b>sqlite_complete()</b> and for memory leaks.</li>
- }
- chng {2000 Dec 4 (1.0.16)} {
- <li>Documentation updates. Mostly fixing of typos and spelling errors.</li>
- }
- chng {2000 Oct 23 (1.0.15)} {
- <li>Documentation updates</li>
- <li>Some sanity checking code was removed from the inner loop of vdbe.c
- to help the library to run a little faster. The code is only
- removed if you compile with -DNDEBUG.</li>
- }
- chng {2000 Oct 19 (1.0.14)} {
- <li>Added a "memory:" backend driver that stores its database in an
- in-memory hash table.</li>
- }
- chng {2000 Oct 18 (1.0.13)} {
- <li>Break out the GDBM driver into a separate file in anticipation
- to added new drivers.</li>
- <li>Allow the name of a database to be prefixed by the driver type.
- For now, the only driver type is "gdbm:".</li>
- }
- chng {2000 Oct 16 (1.0.12)} {
- <li>Fixed an off-by-one error that was causing a coredump in
- the '%q' format directive of the new
- <b>sqlite_..._printf()</b> routines.</li>
- <li>Added the <b>sqlite_interrupt()</b> interface.</li>
- <li>In the shell, <b>sqlite_interrupt()</b> is invoked when the
- user presses Control-C</li>
- <li>Fixed some instances where <b>sqlite_exec()</b> was
- returning the wrong error code.</li>
- }
- chng {2000 Oct 11 (1.0.10)} {
- <li>Added notes on how to compile for Windows95/98.</li>
- <li>Removed a few variables that were not being used. Etc.</li>
- }
- chng {2000 Oct 8 (1.0.9)} {
- <li>Added the <b>sqlite_..._printf()</b> interface routines.</li>
- <li>Modified the <b>sqlite</b> shell program to use the new interface
- routines.</li>
- <li>Modified the <b>sqlite</b> shell program to print the schema for
- the built-in SQLITE_MASTER table, if explicitly requested.</li>
- }
- chng {2000 Sep 30 (1.0.8)} {
- <li>Begin writing documentation on the TCL interface.</li>
- }
- chng {2000 Sep 29 (Not Released)} {
- <li>Added the <b>sqlite_get_table()</b> API</li>
- <li>Updated the documentation for due to the above change.</li>
- <li>Modified the <b>sqlite</b> shell to make use of the new
- sqlite_get_table() API in order to print a list of tables
- in multiple columns, similar to the way "ls" prints filenames.</li>
- <li>Modified the <b>sqlite</b> shell to print a semicolon at the
- end of each CREATE statement in the output of the ".schema" command.</li>
- }
- chng {2000 Sep 21 (Not Released)} {
- <li>Change the tclsqlite "eval" method to return a list of results if
- no callback script is specified.</li>
- <li>Change tclsqlite.c to use the Tcl_Obj interface</li>
- <li>Add tclsqlite.c to the libsqlite.a library</li>
- }
- chng {2000 Sep 13 (Version 1.0.5)} {
- <li>Changed the print format for floating point values from "%g" to "%.15g".
- </li>
- <li>Changed the comparison function so that numbers in exponential notation
- (ex: 1.234e+05) sort in numerical order.</li>
- }
- chng {2000 Aug 28 (Version 1.0.4)} {
- <li>Added functions <b>length()</b> and <b>substr()</b>.</li>
- <li>Fix a bug in the <b>sqlite</b> shell program that was causing
- a coredump when the output mode was "column" and the first row
- of data contained a NULL.</li>
- }
- chng {2000 Aug 22 (Version 1.0.3)} {
- <li>In the sqlite shell, print the "Database opened READ ONLY" message
- to stderr instead of stdout.</li>
- <li>In the sqlite shell, now print the version number on initial startup.</li>
- <li>Add the <b>sqlite_version[]</b> string constant to the library</li>
- <li>Makefile updates</li>
- <li>Bug fix: incorrect VDBE code was being generated for the following
- circumstance: a query on an indexed table containing a WHERE clause with
- an IN operator that had a subquery on its right-hand side.</li>
- }
- chng {2000 Aug 18 (Version 1.0.1)} {
- <li>Fix a bug in the configure script.</li>
- <li>Minor revisions to the website.</li>
- }
- chng {2000 Aug 17 (Version 1.0)} {
- <li>Change the <b>sqlite</b> program so that it can read
- databases for which it lacks write permission. (It used to
- refuse all access if it could not write.)</li>
- }
- chng {2000 Aug 9} {
- <li>Treat carriage returns as white space.</li>
- }
- chng {2000 Aug 8} {
- <li>Added pattern matching to the ".table" command in the "sqlite"
- command shell.</li>
- }
- chng {2000 Aug 4} {
- <li>Documentation updates</li>
- <li>Added "busy" and "timeout" methods to the Tcl interface</li>
- }
- chng {2000 Aug 3} {
- <li>File format version number was being stored in sqlite_master.tcl
- multiple times. This was harmless, but unnecessary. It is now fixed.</li>
- }
- chng {2000 Aug 2} {
- <li>The file format for indices was changed slightly in order to work
- around an inefficiency that can sometimes come up with GDBM when
- there are large indices having many entries with the same key.
- <font color="red">** Incompatible Change **</font></li>
- }
- chng {2000 Aug 1} {
- <li>The parser's stack was overflowing on a very long UPDATE statement.
- This is now fixed.</li>
- }
- chng {2000 July 31} {
- <li>Finish the <a href="vdbe.html">VDBE tutorial</a>.</li>
- <li>Added documentation on compiling to WindowsNT.</li>
- <li>Fix a configuration program for WindowsNT.</li>
- <li>Fix a configuration problem for HPUX.</li>
- }
- chng {2000 July 29} {
- <li>Better labels on column names of the result.</li>
- }
- chng {2000 July 28} {
- <li>Added the <b>sqlite_busy_handler()</b>
- and <b>sqlite_busy_timeout()</b> interface.</li>
- }
- chng {2000 June 23} {
- <li>Begin writing the <a href="vdbe.html">VDBE tutorial</a>.</li>
- }
- chng {2000 June 21} {
- <li>Clean up comments and variable names. Changes to documentation.
- No functional changes to the code.</li>
- }
- chng {2000 June 19} {
- <li>Column names in UPDATE statements were case sensitive.
- This mistake has now been fixed.</li>
- }
- chng {2000 June 16} {
- <li>Added the concatenate string operator (||)</li>
- }
- chng {2000 June 12} {
- <li>Added the fcnt() function to the SQL interpreter. The fcnt() function
- returns the number of database "Fetch" operations that have occurred.
- This function is designed for use in test scripts to verify that
- queries are efficient and appropriately optimized. Fcnt() has no other
- useful purpose, as far as I know.</li>
- <li>Added a bunch more tests that take advantage of the new fcnt() function.
- The new tests did not uncover any new problems.</li>
- }
- chng {2000 June 8} {
- <li>Added lots of new test cases</li>
- <li>Fix a few bugs discovered while adding test cases</li>
- <li>Begin adding lots of new documentation</li>
- }
- chng {2000 June 6} {
- <li>Added compound select operators: <B>UNION</b>, <b>UNION ALL</B>,
- <b>INTERSECT</b>, and <b>EXCEPT</b></li>
- <li>Added support for using <b>(SELECT ...)</b> within expressions</li>
- <li>Added support for <b>IN</b> and <b>BETWEEN</b> operators</li>
- <li>Added support for <b>GROUP BY</b> and <b>HAVING</b></li>
- <li>NULL values are now reported to the callback as a NULL pointer
- rather than an empty string.</li>
- }
- chng {2000 June 3} {
- <li>Added support for default values on columns of a table.</li>
- <li>Improved test coverage. Fixed a few obscure bugs found by the
- improved tests.</li>
- }
- chng {2000 June 2} {
- <li>All database files to be modified by an UPDATE, INSERT or DELETE are
- now locked before any changes are made to any files.
- This makes it safe (I think) to access
- the same database simultaneously from multiple processes.</li>
- <li>The code appears stable so we are now calling it "beta".</li>
- }
- chng {2000 June 1} {
- <li>Better support for file locking so that two or more processes
- (or threads)
- can access the same database simultaneously. More work needed in
- this area, though.</li>
- }
- chng {2000 May 31} {
- <li>Added support for aggregate functions (Ex: <b>COUNT(*)</b>, <b>MIN(...)</b>)
- to the SELECT statement.</li>
- <li>Added support for <B>SELECT DISTINCT ...</B></li>
- }
- chng {2000 May 30} {
- <li>Added the <b>LIKE</b> operator.</li>
- <li>Added a <b>GLOB</b> operator: similar to <B>LIKE</B>
- but it uses Unix shell globbing wildcards instead of the '%'
- and '_' wildcards of SQL.</li>
- <li>Added the <B>COPY</b> command patterned after
- <a href="http://www.postgresql.org/">PostgreSQL</a> so that SQLite
- can now read the output of the <b>pg_dump</b> database dump utility
- of PostgreSQL.</li>
- <li>Added a <B>VACUUM</B> command that that calls the
- <b>gdbm_reorganize()</b> function on the underlying database
- files.</li>
- <li>And many, many bug fixes...</li>
- }
- chng {2000 May 29} {
- <li>Initial Public Release of Alpha code</li>
- }
- puts {
- </DL>
- <p><hr /></p>
- <p><a href="index.html"><img src="/goback.jpg" border=0 />
- Back to the SQLite Home Page</a>
- </p>
- </body></html>}
|