mirror of
				https://github.com/sqlite/sqlite.git
				synced 2025-11-03 16:53:36 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			1881 lines
		
	
	
		
			77 KiB
		
	
	
	
		
			Tcl
		
	
	
	
	
	
			
		
		
	
	
			1881 lines
		
	
	
		
			77 KiB
		
	
	
	
		
			Tcl
		
	
	
	
	
	
#
 | 
						|
# Run this script to generated a changes.html output file
 | 
						|
#
 | 
						|
source common.tcl
 | 
						|
header {SQLite changes}
 | 
						|
puts {
 | 
						|
<p>
 | 
						|
This page provides a high-level summary of changes to SQLite.
 | 
						|
For more detail, refer the the checkin logs generated by
 | 
						|
CVS at
 | 
						|
<a href="http://www.sqlite.org/cvstrac/timeline">
 | 
						|
http://www.sqlite.org/cvstrac/timeline</a>.
 | 
						|
</p>
 | 
						|
 | 
						|
<DL>
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
proc chng {date desc} {
 | 
						|
  if {[regexp {\(([0-9.]+)\)} $date all vers]} {
 | 
						|
    set label [string map {. _} $vers]
 | 
						|
    puts "<A NAME=\"version_$label\">"
 | 
						|
  }
 | 
						|
  puts "<DT><B>$date</B></DT>"
 | 
						|
  regsub -all {[Tt]icket #(\d+)} $desc \
 | 
						|
      {<a href="http://www.sqlite.org/cvstrac/tktview?tn=\1">\0</a>} desc
 | 
						|
  puts "<DD><P><UL>$desc</UL></P>"
 | 
						|
  puts "</DD>"
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 Nov 05 (3.5.2)} {
 | 
						|
<li>Dropped support for the SQLITE_OMIT_MEMORY_ALLOCATION compile-time
 | 
						|
option.
 | 
						|
<li>Always open files using FILE_FLAG_RANDOM_ACCESS under windows.
 | 
						|
<li>The 3rd parameter of the built-in SUBSTR() function is now optional.
 | 
						|
<li>Bug fix: do not invoke the authorizer when reparsing the schema after
 | 
						|
a schema change.
 | 
						|
<li>Added the experimental malloc-free memory allocator in mem3.c.
 | 
						|
<li>Virtual machine stores 64-bit integer and floating point constants
 | 
						|
in binary instead of text for a performance boost.
 | 
						|
<li>Fix a race condition in test_async.c.
 | 
						|
<li>Added the ".timer" command to the CLI
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 Oct 04 (3.5.1)} {
 | 
						|
<li><i><b>Nota Bene:</b> We are not using terms "alpha" or "beta" on this
 | 
						|
    release because the code is stable and because if we use those terms,
 | 
						|
    nobody will upgrade.  However, we still reserve the right to make
 | 
						|
    incompatible changes to the new VFS interface in future releases.</i></li>
 | 
						|
 | 
						|
<li>Fix a bug in the handling of SQLITE_FULL errors that could lead
 | 
						|
    to database corruption.  Ticket #2686.
 | 
						|
<li>The test_async.c drive now does full file locking and works correctly
 | 
						|
    when used simultaneously by multiple processes on the same database.
 | 
						|
<li>The CLI ignores whitespace (including comments) at the end of lines
 | 
						|
<li>Make sure the query optimizer checks dependences on all terms of
 | 
						|
    a compound SELECT statement.  Ticket #2640.
 | 
						|
<li>Add demonstration code showing how to build a VFS for a raw
 | 
						|
    mass storage without a filesystem.
 | 
						|
<li>Added an output buffer size parameter to the xGetTempname() method
 | 
						|
    of the VFS layer.
 | 
						|
<li>Sticky SQLITE_FULL or SQLITE_IOERR errors in the pager are reset
 | 
						|
    when a new transaction is started.
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
chng {2007 Sep 04 (3.5.0) alpha} {
 | 
						|
<li>Redesign the OS interface layer.  See
 | 
						|
    <a href="34to35.html">34to35.html</a> for details.
 | 
						|
    <font color="red">*** Potentially incompatible change ***</font>
 | 
						|
<li>The <a href="capi3ref.html#sqlite3_release_memory">
 | 
						|
    sqlite3_release_memory()</a>,
 | 
						|
    <a href="capi3ref.html#sqlite3_soft_heap_limit">
 | 
						|
    sqlite3_soft_heap_limit()</a>,
 | 
						|
    and <a href="capi3ref.html#sqlite3_enable_shared_cache">
 | 
						|
    sqlite3_enable_shared_cache()</a> interfaces now work cross all
 | 
						|
    threads in the process, not just the single thread in which they
 | 
						|
    are invoked.
 | 
						|
    <font color="red">*** Potentially incompatible change ***</font>
 | 
						|
<li>Added the 
 | 
						|
    <a href="capi3ref.html#sqlite3_open_v2">sqlite3_open_v2()</a>
 | 
						|
    interface.  
 | 
						|
<li>Reimplemented the memory allocation subsystem and made it 
 | 
						|
    replacable at compile-time.
 | 
						|
<li>Created a new mutex subsystem and made it replacable at
 | 
						|
    compile-time.
 | 
						|
<li>The same database connection may now be used simultaneously by
 | 
						|
    separate threads.
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
chng {2007 August 13 (3.4.2)} {
 | 
						|
<li>Fix a database corruption bug that might occur if a ROLLBACK command
 | 
						|
is executed in <a href="pragma.html#pragma_auto_vacuum">auto-vacuum mode</a>
 | 
						|
and a very small <a href="capi3ref.html#sqlite3_soft_heap_limit">
 | 
						|
soft_heap_limit</a> is set. 
 | 
						|
<a href="http://www.sqlite.org/cvstrac/tktview?tn=2565">Ticket #2565</a>.
 | 
						|
 | 
						|
<li>Add the ability to run a full regression test with a small
 | 
						|
<a href="capi3ref.html#sqlite3_soft_heap_limit">soft_heap_limit</a>.
 | 
						|
 | 
						|
<li>Fix other minor problems with using small soft heap limits.
 | 
						|
 | 
						|
<li>Work-around for 
 | 
						|
<a href="http://gcc.gnu.org/bugzilla/show_bug.cgi?id=32575">GCC bug 32575</a>.
 | 
						|
 | 
						|
<li>Improved error detection of misused aggregate functions.
 | 
						|
 | 
						|
<li>Improvements to the amalgamation generator script so that all symbols
 | 
						|
are prefixed with either SQLITE_PRIVATE or SQLITE_API.
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 July 20 (3.4.1)} {
 | 
						|
<li>Fix a bug in <a href="lang_vacuum.html">VACUUM</a> that can lead to
 | 
						|
    <a href="http://www.sqlite.org/cvstrac/wiki?p=DatabaseCorruption">
 | 
						|
    database corruption</a> if two
 | 
						|
    processes are connected to the database at the same time and one
 | 
						|
    VACUUMs then the other then modifies the database.</li>
 | 
						|
<li>The expression "+column" is now considered the same as "column"
 | 
						|
    when computing the collating sequence to use on the expression.</li>
 | 
						|
<li>In the <a href="tclsqlite.html">TCL language interface</a>,
 | 
						|
   "@variable" instead of "$variable" always binds as a blob.</li>
 | 
						|
<li>Added <a href="pragma.html#pragma_freelist_count">PRAGMA freelist_count</a>
 | 
						|
    for determining the current size of the freelist.</li>
 | 
						|
<li>The <a href="pragma.html#pragma_auto_vacuum">
 | 
						|
    PRAGMA auto_vacuum=incremental</a> setting is now persistent.</li>
 | 
						|
<li>Add FD_CLOEXEC to all open files under unix.</li>
 | 
						|
<li>Fix a bug in the <a href="optoverview.html#minmax">
 | 
						|
    min()/max() optimization</a> when applied to
 | 
						|
    descending indices.</li>
 | 
						|
<li>Make sure the TCL language interface works correctly with 64-bit
 | 
						|
    integers on 64-bit machines.</li>
 | 
						|
<li>Allow the value -9223372036854775808 as an integer literal in SQL
 | 
						|
    statements.</li>
 | 
						|
<li>Add the capability of "hidden" columns in virtual tables.</li>
 | 
						|
<li>Use the macro SQLITE_PRIVATE (defaulting to "static") on all
 | 
						|
    internal functions in the amalgamation.</li>
 | 
						|
<li>Add pluggable tokenizers and <a href="http://www.icu-project.org/">ICU</a>
 | 
						|
    tokenization support to FTS2</li>
 | 
						|
<li>Other minor bug fixes and documentation enhancements</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 June 18 (3.4.0)} {
 | 
						|
<li>Fix a bug that can lead to database corruption if an SQLITE_BUSY error
 | 
						|
    occurs in the middle of an explicit transaction and that transaction
 | 
						|
    is later committed.  
 | 
						|
    <a href="http://www.sqlite.org/cvstrac/tktview?tn=2409">Ticket #2409.</a>
 | 
						|
    See the
 | 
						|
    <a href="http://www.sqlite.org/cvstrac/wiki?p=CorruptionFollowingBusyError">
 | 
						|
    CorruptionFollowingBusyError</a> wiki page for details.</i>
 | 
						|
<li>Fix a bug that can lead to database corruption if autovacuum mode is
 | 
						|
    on and a malloc() failure follows a CREATE TABLE or CREATE INDEX statement
 | 
						|
    which itself follows a cache overflow inside a transaction.  See
 | 
						|
    <a href="http://www.sqlite.org/cvstrac/tktview?tn=2418">ticket #2418</a>. 
 | 
						|
    </li>
 | 
						|
<li>Added explicit <a href="limits.html">upper bounds</a> on the sizes and
 | 
						|
    quantities of things SQLite can process.  This change might cause
 | 
						|
    compatibility problems for
 | 
						|
    applications that use SQLite in the extreme, which is why the current
 | 
						|
    release is 3.4.0 instead of 3.3.18.</li>
 | 
						|
<li>Added support for <a href="capi3ref.html#sqlite3_blob_open">
 | 
						|
    Incremental BLOB I/O</a>.</li>
 | 
						|
<li>Added the <a href="capi3ref.html#sqlite3_bind_zeroblob">zeroblob API</a>
 | 
						|
    and the <a href="lang_expr.html#zeroblob">zeroblob()</a> SQL function.</li>
 | 
						|
<li>Added support for <a href="pragma.html#pragma_incremental_vacuum">
 | 
						|
    Incremental Vacuum</a>.</li>
 | 
						|
<li>Added the SQLITE_MIXED_ENDIAN_64BIT_FLOAT compile-time option to suppport
 | 
						|
    ARM7 processors with goofy endianness.</li>
 | 
						|
<li>Removed all instances of sprintf() and strcpy() from the core library.</li>
 | 
						|
<li>Added support for <a href="http://www.icu-project.org/">
 | 
						|
    International Components for Unicode (ICU)</a> to the full-text search
 | 
						|
    extensions.
 | 
						|
</ul><p>
 | 
						|
<ul type="circle">
 | 
						|
<li>In the windows OS driver, reacquire a SHARED lock if an attempt to
 | 
						|
    acquire an EXCLUSIVE lock fails.  Ticket #2354</li>
 | 
						|
<li>Fix the REPLACE() function so that it returns NULL if the second argument
 | 
						|
    is an empty string.  Ticket #2324.</li>
 | 
						|
<li>Document the hazards of type coversions in
 | 
						|
    <a href="capi3ref.html#sqlite3_column_blob">sqlite3_column_blob()</a>
 | 
						|
    and related APIs.  Fix unnecessary type conversions.  Ticket #2321.</li>
 | 
						|
<li>Internationalization of the TRIM() function.  Ticket #2323</li>
 | 
						|
<li>Use memmove() instead of memcpy() when moving between memory regions
 | 
						|
    that might overlap.  Ticket #2334</li>
 | 
						|
<li>Fix an optimizer bug involving subqueries in a compound SELECT that has
 | 
						|
    both an ORDER BY and a LIMIT clause.  Ticket #2339.</li>
 | 
						|
<li>Make sure the <a href="capi3ref.html#sqlite3_snprintf">sqlite3_snprintf()
 | 
						|
    </a> interface does not zero-terminate the buffer if the buffer size is
 | 
						|
    less than 1.  Ticket #2341</li>
 | 
						|
<li>Fix the built-in printf logic so that it prints "NaN" not "Inf" for
 | 
						|
    floating-point NaNs.  Ticket #2345</li>
 | 
						|
<li>When converting BLOB to TEXT, use the text encoding of the main database.
 | 
						|
    Ticket #2349</li>
 | 
						|
<li>Keep the full precision of integers (if possible) when casting to
 | 
						|
    NUMERIC.  Ticket #2364</li>
 | 
						|
<li>Fix a bug in the handling of UTF16 codepoint 0xE000</li>
 | 
						|
<li>Consider explicit collate clauses when matching WHERE constraints
 | 
						|
    to indices in the query optimizer.  Ticket #2391</li>
 | 
						|
<li>Fix the query optimizer to correctly handle constant expressions in 
 | 
						|
    the ON clause of a LEFT JOIN.  Ticket #2403</li>
 | 
						|
<li>Fix the query optimizer to handle rowid comparisions to NULL
 | 
						|
    correctly.  Ticket #2404</li>
 | 
						|
<li>Fix many potental segfaults that could be caused by malicious SQL
 | 
						|
    statements.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 April 25 (3.3.17)} {
 | 
						|
<li>When the "write_version" value of the database header is larger than
 | 
						|
    what the library understands, make the database read-only instead of
 | 
						|
    unreadable.</li>
 | 
						|
<li>Other minor bug fixes</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 April 18 (3.3.16)} {
 | 
						|
<li>Fix a bug that caused VACUUM to fail if NULLs appeared in a
 | 
						|
    UNIQUE column.</li>
 | 
						|
<li>Reinstate performance improvements that were added in 3.3.14
 | 
						|
    but regressed in 3.3.15.</li>
 | 
						|
<li>Fix problems with the handling of ORDER BY expressions on
 | 
						|
    compound SELECT statements in subqueries.</li>
 | 
						|
<li>Fix a potential segfault when destroying locks on WinCE in
 | 
						|
    a multi-threaded environment.</li>
 | 
						|
<li>Documentation updates.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 April 9 (3.3.15)} {
 | 
						|
<li>Fix a bug introduced in 3.3.14 that caused a rollback of
 | 
						|
    CREATE TEMP TABLE to leave the database connection wedged.</li>
 | 
						|
<li>Fix a bug that caused an extra NULL row to be returned when
 | 
						|
    a descending query was interrupted by a change to the database.</li>
 | 
						|
<li>The FOR EACH STATEMENT clause on a trigger now causes a syntax
 | 
						|
    error.  It used to be silently ignored.</li>
 | 
						|
<li>Fix an obscure and relatively harmless problem that might have caused
 | 
						|
    a resource leak following an I/O error.</li>
 | 
						|
<li>Many improvements to the test suite.  Test coverage now exceeded 98%</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 April 2 (3.3.14)} {
 | 
						|
<li>Fix a <a href="http://www.sqlite.org/cvstrac/tktview?tn=2273">bug</a>
 | 
						|
    in 3.3.13 that could cause a segfault when the IN operator
 | 
						|
    is used one one term of a two-column index and the right-hand side of
 | 
						|
    the IN operator contains a NULL.</li>
 | 
						|
<li>Added a new OS interface method for determining the sector size
 | 
						|
    of underlying media:  sqlite3OsSectorSize().</li>
 | 
						|
<li>A new algorithm for statements of the form
 | 
						|
    INSERT INTO <i>table1</i> SELECT * FROM <i>table2</i>
 | 
						|
    is faster and reduces fragmentation.  VACUUM uses statements of
 | 
						|
    this form and thus runs faster and defragments better.</li>
 | 
						|
<li>Performance enhancements through reductions in disk I/O:
 | 
						|
<ul>
 | 
						|
<li>Do not read the last page of an overflow chain when
 | 
						|
    deleting the row - just add that page to the freelist.</li>
 | 
						|
<li>Do not store pages being deleted in the 
 | 
						|
    rollback journal.</li>
 | 
						|
<li>Do not read in the (meaningless) content of
 | 
						|
    pages extracted from the freelist.</li>
 | 
						|
<li>Do not flush the page cache (and thus avoiding
 | 
						|
    a cache refill) unless another process changes the underlying
 | 
						|
    database file.</li>
 | 
						|
<li>Truncate rather than delete the rollback journal when committing
 | 
						|
    a transaction in exclusive access mode, or when committing the TEMP
 | 
						|
    database.</li>
 | 
						|
</ul></li>
 | 
						|
<li>Added support for exclusive access mode using
 | 
						|
    <a href="pragma.html#pragma_locking_mode">
 | 
						|
    "PRAGMA locking_mode=EXCLUSIVE"</a></li>
 | 
						|
<li>Use heap space instead of stack space for large buffers in the
 | 
						|
    pager - useful on embedded platforms with  stack-space
 | 
						|
    limitations.</li>
 | 
						|
<li>Add a makefile target "sqlite3.c" that builds an amalgamation containing
 | 
						|
    the core SQLite library C code in a single file.</li>
 | 
						|
<li>Get the library working correctly when compiled 
 | 
						|
    with GCC option "-fstrict-aliasing".</li>
 | 
						|
<li>Removed the vestigal SQLITE_PROTOCOL error.</li>
 | 
						|
<li>Improvements to test coverage, other minor bugs fixed,
 | 
						|
    memory leaks plugged,
 | 
						|
    code refactored and/or recommented in places for easier reading.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 February 13 (3.3.13)} {
 | 
						|
<li>Add a "fragmentation" measurement in the output of sqlite3_analyzer.</li>
 | 
						|
<li>Add the COLLATE operator used to explicitly set the collating sequence
 | 
						|
used by an expression.  This feature is considered experimental pending
 | 
						|
additional testing.</li>
 | 
						|
<li>Allow up to 64 tables in a join - the old limit was 32.</li>
 | 
						|
<li>Added two new experimental functions:
 | 
						|
<a href="lang_expr.html#randomblobFunc">randomBlob()</a> and
 | 
						|
<a href="lang_expr.html#hexFunc">hex()</a>.
 | 
						|
Their intended use is to facilitate generating 
 | 
						|
<a href="http://en.wikipedia.org/wiki/UUID">UUIDs</a>.
 | 
						|
</li>
 | 
						|
<li>Fix a problem where
 | 
						|
<a href="pragma.html#pragma_count_changes">PRAGMA count_changes</a> was
 | 
						|
causing incorrect results for updates on tables with triggers</li>
 | 
						|
<li>Fix a bug in the ORDER BY clause optimizer for joins where the
 | 
						|
left-most table in the join is constrained by a UNIQUE index.</li>
 | 
						|
<li>Fixed a bug in the "copy" method of the TCL interface.</li>
 | 
						|
<li>Bug fixes in fts1 and fts2 modules.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 January 27 (3.3.12)} {
 | 
						|
<li>Fix another bug in the IS NULL optimization that was added in
 | 
						|
version 3.3.9.</li>
 | 
						|
<li>Fix a assertion fault that occurred on deeply nested views.</li>
 | 
						|
<li>Limit the amount of output that
 | 
						|
<a href="pragma.html#pragma_integrity_check">PRAGMA integrity_check</a>
 | 
						|
generates.</li>
 | 
						|
<li>Minor syntactic changes to support a wider variety of compilers.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 January 22 (3.3.11)} {
 | 
						|
<li>Fix another bug in the implementation of the new 
 | 
						|
<a href="capi3ref.html#sqlite3_prepare_v2">sqlite3_prepare_v2()</a> API.
 | 
						|
We'll get it right eventually...</li>
 | 
						|
<li>Fix a bug in the IS NULL optimization that was added in version 3.3.9 -
 | 
						|
the bug was causing incorrect results on certain LEFT JOINs that included
 | 
						|
in the WHERE clause an IS NULL constraint for the right table of the
 | 
						|
LEFT JOIN.</li>
 | 
						|
<li>Make AreFileApisANSI() a no-op macro in winCE since winCE does not
 | 
						|
support this function.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 January 9 (3.3.10)} {
 | 
						|
<li>Fix bugs in the implementation of the new 
 | 
						|
<a href="capi3ref.html#sqlite3_prepare_v2">sqlite3_prepare_v2()</a> API
 | 
						|
that can lead to segfaults.</li>
 | 
						|
<li>Fix 1-second round-off errors in the 
 | 
						|
<a href="http://www.sqlite.org/cvstrac/wiki?p=DateAndTimeFunctions">
 | 
						|
strftime()</a> function</li>
 | 
						|
<li>Enhance the windows OS layer to provide detailed error codes</li>
 | 
						|
<li>Work around a win2k problem so that SQLite can use single-character
 | 
						|
database file names</li>
 | 
						|
<li>The
 | 
						|
<a href="pragma.html#pragma_user_version">user_version</a> and
 | 
						|
<a href="pragma.html#pragma_schema_version">schema_version</a> pragmas 
 | 
						|
correctly set their column names in the result set</li>
 | 
						|
<li>Documentation updates</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2007 January 4 (3.3.9)} {
 | 
						|
<li>Fix bugs in pager.c that could lead to database corruption if two
 | 
						|
processes both try to recover a hot journal at the same instant</li>
 | 
						|
<li>Added the <a href="capi3ref.html#sqlite3_prepare_v2">sqlite3_prepare_v2()</a>
 | 
						|
API.</li>
 | 
						|
<li>Fixed the ".dump" command in the command-line shell to show
 | 
						|
indices, triggers and views again.</li>
 | 
						|
<li>Change the table_info pragma so that it returns NULL for the default
 | 
						|
value if there is no default value</li>
 | 
						|
<li>Support for non-ASCII characters in win95 filenames</li>
 | 
						|
<li>Query optimizer enhancements:
 | 
						|
<ul>
 | 
						|
<li>Optimizer does a better job of using indices to satisfy ORDER BY
 | 
						|
clauses that sort on the integer primary key</li>
 | 
						|
<li>Use an index to satisfy an IS NULL operator in the WHERE clause</li>
 | 
						|
<li>Fix a bug that was causing the optimizer to miss an OR optimization
 | 
						|
opportunity</li>
 | 
						|
<li>The optimizer has more freedom to reorder tables in the FROM clause
 | 
						|
even in there are LEFT joins.</li>
 | 
						|
</ul>
 | 
						|
<li>Extension loading supported added to winCE</li>
 | 
						|
<li>Allow constraint names on the DEFAULT clause in a table definition</li>
 | 
						|
<li>Added the ".bail" command to the command-line shell</li>
 | 
						|
<li>Make CSV (comma separate value) output from the command-line shell
 | 
						|
more closely aligned to accepted practice</li>
 | 
						|
<li>Experimental FTS2 module added</li>
 | 
						|
<li>Use sqlite3_mprintf() instead of strdup() to avoid libc dependencies</li>
 | 
						|
<li>VACUUM uses a temporary file in the official TEMP folder, not in the
 | 
						|
same directory as the original database</li>
 | 
						|
<li>The prefix on temporary filenames on windows is changed from "sqlite"
 | 
						|
to "etilqs".</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2006 October 9 (3.3.8)} {
 | 
						|
<li>Support for full text search using the
 | 
						|
<a href="http://www.sqlite.org/cvstrac/wiki?p=FullTextIndex">FTS1 module</a>
 | 
						|
(beta)</li>
 | 
						|
<li>Added OS-X locking patches (beta - disabled by default)</li>
 | 
						|
<li>Introduce extended error codes and add error codes for various
 | 
						|
kinds of I/O errors.</li>
 | 
						|
<li>Added support for IF EXISTS on CREATE/DROP TRIGGER/VIEW</li>
 | 
						|
<li>Fix the regression test suite so that it works with Tcl8.5</li>
 | 
						|
<li>Enhance sqlite3_set_authorizer() to provide notification of calls to
 | 
						|
    SQL functions.</li>
 | 
						|
<li>Added experimental API:  sqlite3_auto_extension()</li>
 | 
						|
<li>Various minor bug fixes</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2006 August 12 (3.3.7)} {
 | 
						|
<li>Added support for
 | 
						|
<a href="http://www.sqlite.org/cvstrac/wiki?p=VirtualTables">virtual tables</a>
 | 
						|
(beta)</li>
 | 
						|
<li>Added support for 
 | 
						|
<a href="http://www.sqlite.org/cvstrac/wiki?p=LoadableExtensions">
 | 
						|
dynamically loaded extensions</a> (beta)</li>
 | 
						|
<li>The 
 | 
						|
<a href="capi3ref.html#sqlite3_interrupt">sqlite3_interrupt()</a>
 | 
						|
routine can be called for a different thread</li>
 | 
						|
<li>Added the <a href="lang_expr.html#match">MATCH</a> operator.</li>
 | 
						|
<li>The default file format is now 1.  
 | 
						|
}
 | 
						|
 | 
						|
chng {2006 June 6 (3.3.6)} {
 | 
						|
<li>Plays better with virus scanners on windows</li>
 | 
						|
<li>Faster :memory: databases</li>
 | 
						|
<li>Fix an obscure segfault in UTF-8 to UTF-16 conversions</li>
 | 
						|
<li>Added driver for OS/2</li>
 | 
						|
<li>Correct column meta-information returned for aggregate queries</li>
 | 
						|
<li>Enhanced output from EXPLAIN QUERY PLAN</li>
 | 
						|
<li>LIMIT 0 now works on subqueries</li>
 | 
						|
<li>Bug fixes and performance enhancements in the query optimizer</li>
 | 
						|
<li>Correctly handle NULL filenames in ATTACH and DETACH</li>
 | 
						|
<li>Inproved syntax error messages in the parser</li>
 | 
						|
<li>Fix type coercion rules for the IN operator</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2006 April 5 (3.3.5)} {
 | 
						|
<li>CHECK constraints use conflict resolution algorithms correctly.</li>
 | 
						|
<li>The SUM() function throws an error on integer overflow.</li>
 | 
						|
<li>Choose the column names in a compound query from the left-most SELECT
 | 
						|
    instead of the right-most.</li>
 | 
						|
<li>The sqlite3_create_collation() function
 | 
						|
    honors the SQLITE_UTF16_ALIGNED flag.</li>
 | 
						|
<li>SQLITE_SECURE_DELETE compile-time option causes deletes to overwrite
 | 
						|
    old data with zeros.</li>
 | 
						|
<li>Detect integer overflow in abs().</li>
 | 
						|
<li>The random() function provides 64 bits of randomness instead of
 | 
						|
    only 32 bits.</li>
 | 
						|
<li>Parser detects and reports automaton stack overflow.</li>
 | 
						|
<li>Change the round() function to return REAL instead of TEXT.</li>
 | 
						|
<li>Allow WHERE clause terms on the left table of a LEFT OUTER JOIN to
 | 
						|
    contain aggregate subqueries.</li>
 | 
						|
<li>Skip over leading spaces in text to numeric conversions.</li>
 | 
						|
<li>Various minor bug and documentation typo fixes and
 | 
						|
    performance enhancements.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2006 February 11 (3.3.4)} {
 | 
						|
<li>Fix a blunder in the Unix mutex implementation that can lead to
 | 
						|
deadlock on multithreaded systems.</li>
 | 
						|
<li>Fix an alignment problem on 64-bit machines</li>
 | 
						|
<li>Added the fullfsync pragma.</li>
 | 
						|
<li>Fix an optimizer bug that could have caused some unusual LEFT OUTER JOINs
 | 
						|
to give incorrect results.</li>
 | 
						|
<li>The SUM function detects integer overflow and converts to accumulating
 | 
						|
an approximate result using floating point numbers</li>
 | 
						|
<li>Host parameter names can begin with '@' for compatibility with SQL Server.
 | 
						|
</li>
 | 
						|
<li>Other miscellaneous bug fixes</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2006 January 31 (3.3.3)} {
 | 
						|
<li>Removed support for an ON CONFLICT clause on CREATE INDEX - it never
 | 
						|
worked correctly so this should not present any backward compatibility
 | 
						|
problems.</li>
 | 
						|
<li>Authorizer callback now notified of ALTER TABLE ADD COLUMN commands</li>
 | 
						|
<li>After any changes to the TEMP database schema, all prepared statements
 | 
						|
are invalidated and must be recreated using a new call to
 | 
						|
sqlite3_prepare()</li>
 | 
						|
<li>Other minor bug fixes in preparation for the first stable release
 | 
						|
of version 3.3</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2006 January 24 (3.3.2 beta)} {
 | 
						|
<li>Bug fixes and speed improvements.  Improved test coverage.</li>
 | 
						|
<li>Changes to the OS-layer interface: mutexes must now be recursive.</li>
 | 
						|
<li>Discontinue the use of thread-specific data for out-of-memory
 | 
						|
exception handling</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2006 January 16 (3.3.1 alpha)} {
 | 
						|
<li>Countless bug fixes</li>
 | 
						|
<li>Speed improvements</li>
 | 
						|
<li>Database connections can now be used by multiple threads, not just
 | 
						|
the thread in which they were created.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2006 January 10 (3.3.0 alpha)} {
 | 
						|
<li>CHECK constraints</li>
 | 
						|
<li>IF EXISTS and IF NOT EXISTS clauses on CREATE/DROP TABLE/INDEX.</li>
 | 
						|
<li>DESC indices</li>
 | 
						|
<li>More efficient encoding of boolean values resulting in smaller database
 | 
						|
files</li>
 | 
						|
<li>More aggressive SQLITE_OMIT_FLOATING_POINT</li>
 | 
						|
<li>Separate INTEGER and REAL affinity</li>
 | 
						|
<li>Added a virtual function layer for the OS interface</li>
 | 
						|
<li>"exists" method added to the TCL interface</li>
 | 
						|
<li>Improved response to out-of-memory errors</li>
 | 
						|
<li>Database cache can be optionally shared between connections
 | 
						|
in the same thread</li>
 | 
						|
<li>Optional READ UNCOMMITTED isolation (instead of the default
 | 
						|
isolation level of SERIALIZABLE) and table level locking when
 | 
						|
database connections share a common cache.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 December 19 (3.2.8)} {
 | 
						|
<li>Fix an obscure bug that can cause database corruption under the
 | 
						|
following unusual circumstances: A large INSERT or UPDATE statement which 
 | 
						|
is part of an even larger transaction fails due to a uniqueness contraint
 | 
						|
but the containing transaction commits.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 December 19 (2.8.17)} {
 | 
						|
<li>Fix an obscure bug that can cause database corruption under the
 | 
						|
following unusual circumstances: A large INSERT or UPDATE statement which 
 | 
						|
is part of an even larger transaction fails due to a uniqueness contraint
 | 
						|
but the containing transaction commits.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 September 24 (3.2.7)} {
 | 
						|
<li>GROUP BY now considers NULLs to be equal again, as it should
 | 
						|
</li>
 | 
						|
<li>Now compiles on Solaris and OpenBSD and other Unix variants
 | 
						|
that lack the fdatasync() function</li>
 | 
						|
<li>Now compiles on MSVC++6 again</li>
 | 
						|
<li>Fix uninitialized variables causing malfunctions for various obscure
 | 
						|
queries</li>
 | 
						|
<li>Correctly compute a LEFT OUTER JOINs that is constrained on the
 | 
						|
left table only</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 September 17 (3.2.6)} {
 | 
						|
<li>Fix a bug that can cause database corruption if a VACUUM (or
 | 
						|
    autovacuum) fails and is rolled back on a database that is
 | 
						|
    larger than 1GiB</li>
 | 
						|
<li>LIKE optiization now works for columns with COLLATE NOCASE</li>
 | 
						|
<li>ORDER BY and GROUP BY now use bounded memory</li>
 | 
						|
<li>Added support for COUNT(DISTINCT expr)</li>
 | 
						|
<li>Change the way SUM() handles NULL values in order to comply with
 | 
						|
    the SQL standard</li>
 | 
						|
<li>Use fdatasync() instead of fsync() where possible in order to speed
 | 
						|
    up commits slightly</li>
 | 
						|
<li>Use of the CROSS keyword in a join turns off the table reordering
 | 
						|
    optimization</li>
 | 
						|
<li>Added the experimental and undocumented EXPLAIN QUERY PLAN capability</li>
 | 
						|
<li>Use the unicode API in windows</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 August 27 (3.2.5)} {
 | 
						|
<li>Fix a bug effecting DELETE and UPDATE statements that changed
 | 
						|
more than 40960 rows.</li>
 | 
						|
<li>Change the makefile so that it no longer requires GNUmake extensions</li>
 | 
						|
<li>Fix the --enable-threadsafe option on the configure script</li>
 | 
						|
<li>Fix a code generator bug that occurs when the left-hand side of an IN
 | 
						|
operator is constant and the right-hand side is a SELECT statement</li>
 | 
						|
<li>The PRAGMA synchronous=off statement now disables syncing of the
 | 
						|
master journal file in addition to the normal rollback journals</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 August 24 (3.2.4)} {
 | 
						|
<li>Fix a bug introduced in the previous release
 | 
						|
that can cause a segfault while generating code
 | 
						|
for complex WHERE clauses.</li>
 | 
						|
<li>Allow floating point literals to begin or end with a decimal point.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 August 21 (3.2.3)} {
 | 
						|
<li>Added support for the CAST operator</li>
 | 
						|
<li>Tcl interface allows BLOB values to be transferred to user-defined
 | 
						|
functions</li>
 | 
						|
<li>Added the "transaction" method to the Tcl interface</li>
 | 
						|
<li>Allow the DEFAULT value of a column to call functions that have constant
 | 
						|
operands</li>
 | 
						|
<li>Added the ANALYZE command for gathering statistics on indices and
 | 
						|
using those statistics when picking an index in the optimizer</li>
 | 
						|
<li>Remove the limit (formerly 100) on the number of terms in the
 | 
						|
WHERE clause</li>
 | 
						|
<li>The right-hand side of the IN operator can now be a list of expressions
 | 
						|
instead of just a list of constants</li>
 | 
						|
<li>Rework the optimizer so that it is able to make better use of indices</li>
 | 
						|
<li>The order of tables in a join is adjusted automatically to make
 | 
						|
better use of indices</li>
 | 
						|
<li>The IN operator is now a candidate for optimization even if the left-hand
 | 
						|
side is not the left-most term of the index.  Multiple IN operators can be
 | 
						|
used with the same index.</li>
 | 
						|
<li>WHERE clause expressions using BETWEEN and OR are now candidates
 | 
						|
for optimization</li>
 | 
						|
<li>Added the "case_sensitive_like" pragma and the SQLITE_CASE_SENSITIVE_LIKE
 | 
						|
compile-time option to set its default value to "on".</li>
 | 
						|
<li>Use indices to help with GLOB expressions and LIKE expressions too
 | 
						|
when the case_sensitive_like pragma is enabled</li>
 | 
						|
<li>Added support for grave-accent quoting for compatibility with MySQL</li>
 | 
						|
<li>Improved test coverage</li>
 | 
						|
<li>Dozens of minor bug fixes</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 June 13 (3.2.2)} {
 | 
						|
<li>Added the sqlite3_db_handle() API</li>
 | 
						|
<li>Added the sqlite3_get_autocommit() API</li>
 | 
						|
<li>Added a REGEXP operator to the parser.  There is no function to back
 | 
						|
up this operator in the standard build but users can add their own using
 | 
						|
sqlite3_create_function()</li>
 | 
						|
<li>Speed improvements and library footprint reductions.</li>
 | 
						|
<li>Fix byte alignment problems on 64-bit architectures.</li>
 | 
						|
<li>Many, many minor bug fixes and documentation updates.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 March 29 (3.2.1)} {
 | 
						|
<li>Fix a memory allocation error in the new ADD COLUMN comment.</li>
 | 
						|
<li>Documentation updates</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 March 21 (3.2.0)} {
 | 
						|
<li>Added support for ALTER TABLE ADD COLUMN.</li>
 | 
						|
<li>Added support for the "T" separator in ISO-8601 date/time strings.</li>
 | 
						|
<li>Improved support for Cygwin.</li>
 | 
						|
<li>Numerous bug fixes and documentation updates.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 March 16 (3.1.6)} {
 | 
						|
<li>Fix a bug that could cause database corruption when inserting
 | 
						|
    record into tables with around 125 columns.</li>
 | 
						|
<li>sqlite3_step() is now much more likely to invoke the busy handler
 | 
						|
    and less likely to return SQLITE_BUSY.</li>
 | 
						|
<li>Fix memory leaks that used to occur after a malloc() failure.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 March 11 (3.1.5)} {
 | 
						|
<li>The ioctl on OS-X to control syncing to disk is F_FULLFSYNC,
 | 
						|
    not F_FULLSYNC.  The previous release had it wrong.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 March 10 (3.1.4)} {
 | 
						|
<li>Fix a bug in autovacuum that could cause database corruption if
 | 
						|
a CREATE UNIQUE INDEX fails because of a constraint violation.
 | 
						|
This problem only occurs if the new autovacuum feature introduced in
 | 
						|
version 3.1 is turned on.</li>
 | 
						|
<li>The F_FULLSYNC ioctl (currently only supported on OS-X) is disabled
 | 
						|
if the synchronous pragma is set to something other than "full".</li>
 | 
						|
<li>Add additional forward compatibility to the future version 3.2 database 
 | 
						|
file format.</li>
 | 
						|
<li>Fix a bug in WHERE clauses of the form (rowid<'2')</li>
 | 
						|
<li>New SQLITE_OMIT_... compile-time options added</li>
 | 
						|
<li>Updates to the man page</li>
 | 
						|
<li>Remove the use of strcasecmp() from the shell</li>
 | 
						|
<li>Windows DLL exports symbols Tclsqlite_Init and Sqlite_Init</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 February 19 (3.1.3)} {
 | 
						|
<li>Fix a problem with VACUUM on databases from which tables containing
 | 
						|
AUTOINCREMENT have been dropped.</li>
 | 
						|
<li>Add forward compatibility to the future version 3.2 database file
 | 
						|
format.</li>
 | 
						|
<li>Documentation updates</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 February 15 (3.1.2)} {
 | 
						|
<li>Fix a bug that can lead to database corruption if there are two
 | 
						|
open connections to the same database and one connection does a VACUUM
 | 
						|
and the second makes some change to the database.</li>
 | 
						|
<li>Allow "?" parameters in the LIMIT clause.</li>
 | 
						|
<li>Fix VACUUM so that it works with AUTOINCREMENT.</li>
 | 
						|
<li>Fix a race condition in AUTOVACUUM that can lead to corrupt databases</li>
 | 
						|
<li>Add a numeric version number to the sqlite3.h include file.</li>
 | 
						|
<li>Other minor bug fixes and performance enhancements.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 February 15 (2.8.16)} {
 | 
						|
<li>Fix a bug that can lead to database corruption if there are two
 | 
						|
open connections to the same database and one connection does a VACUUM
 | 
						|
and the second makes some change to the database.</li>
 | 
						|
<li>Correctly handle quoted names in CREATE INDEX statements.</li>
 | 
						|
<li>Fix a naming conflict between sqlite.h and sqlite3.h.</li>
 | 
						|
<li>Avoid excess heap usage when copying expressions.</li>
 | 
						|
<li>Other minor bug fixes.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 February 1 (3.1.1 BETA)} {
 | 
						|
<li>Automatic caching of prepared statements in the TCL interface</li>
 | 
						|
<li>ATTACH and DETACH as well as some other operations cause existing
 | 
						|
    prepared statements to expire.</li>
 | 
						|
<li>Numerious minor bug fixes</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2005 January 21 (3.1.0 ALPHA)} {
 | 
						|
<li>Autovacuum support added</li>
 | 
						|
<li>CURRENT_TIME, CURRENT_DATE, and CURRENT_TIMESTAMP added</li>
 | 
						|
<li>Support for the EXISTS clause added.</li>
 | 
						|
<li>Support for correlated subqueries added.</li>
 | 
						|
<li>Added the ESCAPE clause on the LIKE operator.</li>
 | 
						|
<li>Support for ALTER TABLE ... RENAME TABLE ... added</li>
 | 
						|
<li>AUTOINCREMENT keyword supported on INTEGER PRIMARY KEY</li>
 | 
						|
<li>Many SQLITE_OMIT_ macros inserts to omit features at compile-time
 | 
						|
    and reduce the library footprint.</li>
 | 
						|
<li>The REINDEX command was added.</li>
 | 
						|
<li>The engine no longer consults the main table if it can get
 | 
						|
    all the information it needs from an index.</li>
 | 
						|
<li>Many nuisance bugs fixed.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 October 11 (3.0.8)} {
 | 
						|
<li>Add support for DEFERRED, IMMEDIATE, and EXCLUSIVE transactions.</li>
 | 
						|
<li>Allow new user-defined functions to be created when there are
 | 
						|
already one or more precompiled SQL statements.<li>
 | 
						|
<li>Fix portability problems for Mingw/MSYS.</li>
 | 
						|
<li>Fix a byte alignment problem on 64-bit Sparc machines.</li>
 | 
						|
<li>Fix the ".import" command of the shell so that it ignores \r
 | 
						|
characters at the end of lines.</li>
 | 
						|
<li>The "csv" mode option in the shell puts strings inside double-quotes.</li>
 | 
						|
<li>Fix typos in documentation.</li>
 | 
						|
<li>Convert array constants in the code to have type "const".</li>
 | 
						|
<li>Numerous code optimizations, specially optimizations designed to
 | 
						|
make the code footprint smaller.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 September 18 (3.0.7)} {
 | 
						|
<li>The BTree module allocates large buffers using malloc() instead of
 | 
						|
    off of the stack, in order to play better on machines with limited
 | 
						|
    stack space.</li>
 | 
						|
<li>Fixed naming conflicts so that versions 2.8 and 3.0 can be
 | 
						|
    linked and used together in the same ANSI-C source file.</li>
 | 
						|
<li>New interface: sqlite3_bind_parameter_index()</li>
 | 
						|
<li>Add support for wildcard parameters of the form: "?nnn"</li>
 | 
						|
<li>Fix problems found on 64-bit systems.</li>
 | 
						|
<li>Removed encode.c file (containing unused routines) from the 
 | 
						|
    version 3.0 source tree.</li>
 | 
						|
<li>The sqlite3_trace() callbacks occur before each statement
 | 
						|
    is executed, not when the statement is compiled.</li>
 | 
						|
<li>Makefile updates and miscellaneous bug fixes.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 September 02 (3.0.6 beta)} {
 | 
						|
<li>Better detection and handling of corrupt database files.</li>
 | 
						|
<li>The sqlite3_step() interface returns SQLITE_BUSY if it is unable
 | 
						|
    to commit a change because of a lock</li>
 | 
						|
<li>Combine the implementations of LIKE and GLOB into a single
 | 
						|
    pattern-matching subroutine.</li>
 | 
						|
<li>Miscellaneous code size optimizations and bug fixes</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 August 29 (3.0.5 beta)} {
 | 
						|
<li>Support for ":AAA" style bind parameter names.</li>
 | 
						|
<li>Added the new sqlite3_bind_parameter_name() interface.</li>
 | 
						|
<li>Support for TCL variable names embedded in SQL statements in the
 | 
						|
    TCL bindings.</li>
 | 
						|
<li>The TCL bindings transfer data without necessarily doing a conversion
 | 
						|
    to a string.</li>
 | 
						|
<li>The database for TEMP tables is not created until it is needed.</li>
 | 
						|
<li>Add the ability to specify an alternative temporary file directory
 | 
						|
    using the "sqlite_temp_directory" global variable.</li>
 | 
						|
<li>A compile-time option (SQLITE_BUSY_RESERVED_LOCK) causes the busy
 | 
						|
    handler to be called when there is contention for a RESERVED lock.</li>
 | 
						|
<li>Various bug fixes and optimizations</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 August 8 (3.0.4 beta)} {
 | 
						|
<li>CREATE TABLE and DROP TABLE now work correctly as prepared statements.</li>
 | 
						|
<li>Fix a bug in VACUUM and UNIQUE indices.</li>
 | 
						|
<li>Add the ".import" command to the command-line shell.</li>
 | 
						|
<li>Fix a bug that could cause index corruption when an attempt to
 | 
						|
    delete rows of a table is blocked by a pending query.</li>
 | 
						|
<li>Library size optimizations.</li>
 | 
						|
<li>Other minor bug fixes.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 July 22 (2.8.15)} {
 | 
						|
<li>This is a maintenance release only.  Various minor bugs have been
 | 
						|
fixed and some portability enhancements are added.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 July 22 (3.0.3 beta)} {
 | 
						|
<li>The second beta release for SQLite 3.0.</li>
 | 
						|
<li>Add support for "PRAGMA page_size" to adjust the page size of
 | 
						|
the database.</li>
 | 
						|
<li>Various bug fixes and documentation updates.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 June 30 (3.0.2 beta)} {
 | 
						|
<li>The first beta release for SQLite 3.0.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 June 22 (3.0.1 alpha)} {
 | 
						|
<li><font color="red"><b>
 | 
						|
    *** Alpha Release - Research And Testing Use Only ***</b></font>
 | 
						|
<li>Lots of bug fixes.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 June 18 (3.0.0 alpha)} {
 | 
						|
<li><font color="red"><b>
 | 
						|
    *** Alpha Release - Research And Testing Use Only ***</b></font>
 | 
						|
<li>Support for internationalization including UTF-8, UTF-16, and
 | 
						|
    user defined collating sequences.</li>
 | 
						|
<li>New file format that is 25% to 35% smaller for typical use.</li>
 | 
						|
<li>Improved concurrency.</li>
 | 
						|
<li>Atomic commits for ATTACHed databases.</li>
 | 
						|
<li>Remove cruft from the APIs.</li>
 | 
						|
<li>BLOB support.</li>
 | 
						|
<li>64-bit rowids.</li>
 | 
						|
<li><a href="version3.html">More information</a>.
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 June 9 (2.8.14)} {
 | 
						|
<li>Fix the min() and max() optimizer so that it works when the FROM
 | 
						|
    clause consists of a subquery.</li>
 | 
						|
<li>Ignore extra whitespace at the end of of "." commands in the shell.</li>
 | 
						|
<li>Bundle sqlite_encode_binary() and sqlite_decode_binary() with the 
 | 
						|
    library.</li>
 | 
						|
<li>The TEMP_STORE and DEFAULT_TEMP_STORE pragmas now work.</li>
 | 
						|
<li>Code changes to compile cleanly using OpenWatcom.</li>
 | 
						|
<li>Fix VDBE stack overflow problems with INSTEAD OF triggers and
 | 
						|
    NULLs in IN operators.</li>
 | 
						|
<li>Add the global variable sqlite_temp_directory which if set defines the
 | 
						|
    directory in which temporary files are stored.</li>
 | 
						|
<li>sqlite_interrupt() plays well with VACUUM.</li>
 | 
						|
<li>Other minor bug fixes.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 March 8 (2.8.13)} {
 | 
						|
<li>Refactor parts of the code in order to make the code footprint
 | 
						|
    smaller.  The code is now also a little bit faster.</li>
 | 
						|
<li>sqlite_exec() is now implemented as a wrapper around sqlite_compile()
 | 
						|
    and sqlite_step().</li>
 | 
						|
<li>The built-in min() and max() functions now honor the difference between
 | 
						|
    NUMERIC and TEXT datatypes.  Formerly, min() and max() always assumed
 | 
						|
    their arguments were of type NUMERIC.</li>
 | 
						|
<li>New HH:MM:SS modifier to the built-in date/time functions.</li>
 | 
						|
<li>Experimental sqlite_last_statement_changes() API added.  Fixed the
 | 
						|
    the last_insert_rowid() function so that it works correctly with
 | 
						|
    triggers.</li>
 | 
						|
<li>Add functions prototypes for the database encryption API.</li>
 | 
						|
<li>Fix several nuisance bugs.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 February 8 (2.8.12)} {
 | 
						|
<li>Fix a bug that will might corrupt the rollback journal if a power failure
 | 
						|
    or external program halt occurs in the middle of a COMMIT.  The corrupt
 | 
						|
    journal can lead to database corruption when it is rolled back.</li>
 | 
						|
<li>Reduce the size and increase the speed of various modules, especially
 | 
						|
    the virtual machine.</li>
 | 
						|
<li>Allow "<expr> IN <table>" as a shorthand for
 | 
						|
    "<expr> IN (SELECT * FROM <table>".</li>
 | 
						|
<li>Optimizations to the sqlite_mprintf() routine.</li>
 | 
						|
<li>Make sure the MIN() and MAX() optimizations work within subqueries.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 January 14 (2.8.11)} {
 | 
						|
<li>Fix a bug in how the IN operator handles NULLs in subqueries.  The bug
 | 
						|
    was introduced by the previous release.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 January 13 (2.8.10)} {
 | 
						|
<li>Fix a potential database corruption problem on Unix caused by the fact
 | 
						|
    that all posix advisory locks are cleared whenever you close() a file.
 | 
						|
    The work around it to embargo all close() calls while locks are 
 | 
						|
    outstanding.</li>
 | 
						|
<li>Performance enhancements on some corner cases of COUNT(*).</li>
 | 
						|
<li>Make sure the in-memory backend response sanely if malloc() fails.</li>
 | 
						|
<li>Allow sqlite_exec() to be called from within user-defined SQL
 | 
						|
    functions.</li>
 | 
						|
<li>Improved accuracy of floating-point conversions using "long double".</li>
 | 
						|
<li>Bug fixes in the experimental date/time functions.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2004 January 5 (2.8.9)} {
 | 
						|
<li>Fix a 32-bit integer overflow problem that could result in corrupt
 | 
						|
    indices in a database if large negative numbers (less than -2147483648)
 | 
						|
    were inserted into a indexed numeric column.</li>
 | 
						|
<li>Fix a locking problem on multi-threaded Linux implementations.</li>
 | 
						|
<li>Always use "." instead of "," as the decimal point even if the locale
 | 
						|
    requests ",".</li>
 | 
						|
<li>Added UTC to localtime conversions to the experimental date/time
 | 
						|
    functions.</li>
 | 
						|
<li>Bug fixes to date/time functions.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2003 December 17 (2.8.8)} {
 | 
						|
<li>Fix a critical bug introduced into 2.8.0 which could cause
 | 
						|
    database corruption.</li>
 | 
						|
<li>Fix a problem with 3-way joins that do not use indices</li>
 | 
						|
<li>The VACUUM command now works with the non-callback API</li>
 | 
						|
<li>Improvements to the "PRAGMA integrity_check" command</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2003 December 4 (2.8.7)} {
 | 
						|
<li>Added experimental sqlite_bind() and sqlite_reset() APIs.</li>
 | 
						|
<li>If the name of the database is an empty string, open a new database
 | 
						|
    in a temporary file that is automatically deleted when the database
 | 
						|
    is closed.</li>
 | 
						|
<li>Performance enhancements in the lemon-generated parser</li>
 | 
						|
<li>Experimental date/time functions revised.</li>
 | 
						|
<li>Disallow temporary indices on permanent tables.</li>
 | 
						|
<li>Documentation updates and typo fixes</li>
 | 
						|
<li>Added experimental sqlite_progress_handler() callback API</li>
 | 
						|
<li>Removed support for the Oracle8 outer join syntax.</li>
 | 
						|
<li>Allow GLOB and LIKE operators to work as functions.</li>
 | 
						|
<li>Other minor documentation and makefile changes and bug fixes.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2003 August 21 (2.8.6)} {
 | 
						|
<li>Moved the CVS repository to www.sqlite.org</li>
 | 
						|
<li>Update the NULL-handling documentation.</li>
 | 
						|
<li>Experimental date/time functions added.</li>
 | 
						|
<li>Bug fix: correctly evaluate a view of a view without segfaulting.</li>
 | 
						|
<li>Bug fix: prevent database corruption if you dropped a
 | 
						|
    trigger that had the same name as a table.</li>
 | 
						|
<li>Bug fix: allow a VACUUM (without segfaulting) on an empty
 | 
						|
    database after setting the EMPTY_RESULT_CALLBACKS pragma.</li>
 | 
						|
<li>Bug fix: if an integer value will not fit in a 32-bit int, store it in
 | 
						|
    a double instead.</li>
 | 
						|
<li>Bug fix: Make sure the journal file directory entry is committed to disk
 | 
						|
    before writing the database file.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2003 July 22 (2.8.5)} {
 | 
						|
<li>Make LIMIT work on a compound SELECT statement.</li>
 | 
						|
<li>LIMIT 0 now shows no rows.  Use LIMIT -1 to see all rows.</li>
 | 
						|
<li>Correctly handle comparisons between an INTEGER PRIMARY KEY and
 | 
						|
    a floating point number.</li>
 | 
						|
<li>Fix several important bugs in the new ATTACH and DETACH commands.</li>
 | 
						|
<li>Updated the <a href="nulls.html">NULL-handling document</a>.</li> 
 | 
						|
<li>Allow NULL arguments in sqlite_compile() and sqlite_step().</li>
 | 
						|
<li>Many minor bug fixes</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2003 June 29 (2.8.4)} {
 | 
						|
<li>Enhanced the "PRAGMA integrity_check" command to verify indices.</li>
 | 
						|
<li>Added authorization hooks for the new ATTACH and DETACH commands.</li>
 | 
						|
<li>Many documentation updates</li>
 | 
						|
<li>Many minor bug fixes</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2003 June 4 (2.8.3)} {
 | 
						|
<li>Fix a problem that will corrupt the indices on a table if you
 | 
						|
    do an INSERT OR REPLACE or an UPDATE OR REPLACE on a table that
 | 
						|
    contains an INTEGER PRIMARY KEY plus one or more indices.</li>
 | 
						|
<li>Fix a bug in windows locking code so that locks work correctly
 | 
						|
    when simultaneously accessed by Win95 and WinNT systems.</li>
 | 
						|
<li>Add the ability for INSERT and UPDATE statements to refer to the
 | 
						|
    "rowid" (or "_rowid_" or "oid") columns.</li>
 | 
						|
<li>Other important bug fixes</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2003 May 17 (2.8.2)} {
 | 
						|
<li>Fix a problem that will corrupt the database file if you drop a
 | 
						|
    table from the main database that has a TEMP index.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2003 May 16 (2.8.1)} {
 | 
						|
<li>Reactivated the VACUUM command that reclaims unused disk space in 
 | 
						|
    a database file.</li>
 | 
						|
<li>Added the ATTACH and DETACH commands to allow interacting with multiple
 | 
						|
    database files at the same time.</li>
 | 
						|
<li>Added support for TEMP triggers and indices.</li>
 | 
						|
<li>Added support for in-memory databases.</li>
 | 
						|
<li>Removed the experimental sqlite_open_aux_file().  Its function is
 | 
						|
    subsumed in the new ATTACH command.</li>
 | 
						|
<li>The precedence order for ON CONFLICT clauses was changed so that
 | 
						|
    ON CONFLICT clauses on BEGIN statements have a higher precedence than
 | 
						|
    ON CONFLICT clauses on constraints.
 | 
						|
<li>Many, many bug fixes and compatibility enhancements.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2003 Feb 16 (2.8.0)} {
 | 
						|
<li>Modified the journal file format to make it more resistant to corruption
 | 
						|
    that can occur after an OS crash or power failure.</li>
 | 
						|
<li>Added a new C/C++ API that does not use callback for returning data.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2003 Jan 25 (2.7.6)} {
 | 
						|
<li>Performance improvements.  The library is now much faster.</li>
 | 
						|
<li>Added the <b>sqlite_set_authorizer()</b> API.  Formal documentation has
 | 
						|
    not been written - see the source code comments for instructions on
 | 
						|
    how to use this function.</li>
 | 
						|
<li>Fix a bug in the GLOB operator that was preventing it from working
 | 
						|
    with upper-case letters.</li>
 | 
						|
<li>Various minor bug fixes.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Dec 27 (2.7.5)} {
 | 
						|
<li>Fix an uninitialized variable in pager.c which could (with a probability
 | 
						|
    of about 1 in 4 billion) result in a corrupted database.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Dec 17 (2.7.4)} {
 | 
						|
<li>Database files can now grow to be up to 2^41 bytes.  The old limit
 | 
						|
    was 2^31 bytes.</li>
 | 
						|
<li>The optimizer will now scan tables in the reverse if doing so will
 | 
						|
    satisfy an ORDER BY ... DESC clause.</li>
 | 
						|
<li>The full pathname of the database file is now remembered even if
 | 
						|
    a relative path is passed into sqlite_open().  This allows 
 | 
						|
    the library to continue operating correctly after a chdir().</li>
 | 
						|
<li>Speed improvements in the VDBE.</li>
 | 
						|
<li>Lots of little bug fixes.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Oct 30 (2.7.3)} {
 | 
						|
<li>Various compiler compatibility fixes.</li>
 | 
						|
<li>Fix a bug in the "expr IN ()" operator.</li>
 | 
						|
<li>Accept column names in parentheses.</li>
 | 
						|
<li>Fix a problem with string memory management in the VDBE</li>
 | 
						|
<li>Fix a bug in the "table_info" pragma"</li>
 | 
						|
<li>Export the sqlite_function_type() API function in the Windows DLL</li>
 | 
						|
<li>Fix locking behavior under windows</li>
 | 
						|
<li>Fix a bug in LEFT OUTER JOIN</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Sep 25 (2.7.2)} {
 | 
						|
<li>Prevent journal file overflows on huge transactions.</li>
 | 
						|
<li>Fix a memory leak that occurred when sqlite_open() failed.</li>
 | 
						|
<li>Honor the ORDER BY and LIMIT clause of a SELECT even if the
 | 
						|
    result set is used for an INSERT.</li>
 | 
						|
<li>Do not put write locks on the file used to hold TEMP tables.</li>
 | 
						|
<li>Added documentation on SELECT DISTINCT and on how SQLite handles NULLs.</li>
 | 
						|
<li>Fix a problem that was causing poor performance when many thousands
 | 
						|
    of SQL statements were executed by a single sqlite_exec() call.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Aug 31 (2.7.1)} {
 | 
						|
<li>Fix a bug in the ORDER BY logic that was introduced in version 2.7.0</li>
 | 
						|
<li>C-style comments are now accepted by the tokenizer.</li>
 | 
						|
<li>INSERT runs a little faster when the source is a SELECT statement.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Aug 25 (2.7.0)} {
 | 
						|
<li>Make a distinction between numeric and text values when sorting.
 | 
						|
    Text values sort according to memcmp().  Numeric values sort in
 | 
						|
    numeric order.</li>
 | 
						|
<li>Allow multiple simultaneous readers under windows by simulating
 | 
						|
    the reader/writers locks that are missing from Win95/98/ME.</li>
 | 
						|
<li>An error is now returned when trying to start a transaction if
 | 
						|
    another transaction is already active.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Aug 12 (2.6.3)} {
 | 
						|
<li>Add the ability to read both little-endian and big-endian databases.
 | 
						|
    So database created under SunOS or MacOSX can be read and written
 | 
						|
    under Linux or Windows and vice versa.</li>
 | 
						|
<li>Convert to the new website: http://www.sqlite.org/</li>
 | 
						|
<li>Allow transactions to span Linux Threads</li>
 | 
						|
<li>Bug fix in the processing of the ORDER BY clause for GROUP BY queries</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Jly 30 (2.6.2)} {
 | 
						|
<li>Text files read by the COPY command can now have line terminators
 | 
						|
    of LF,  CRLF, or CR.</li>
 | 
						|
<li>SQLITE_BUSY is handled correctly if encountered during database
 | 
						|
    initialization.</li>
 | 
						|
<li>Fix to UPDATE triggers on TEMP tables.</li>
 | 
						|
<li>Documentation updates.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Jly 19 (2.6.1)} {
 | 
						|
<li>Include a static string in the library that responds to the RCS
 | 
						|
    "ident" command and which contains the library version number.</li>
 | 
						|
<li>Fix an assertion failure that occurred when deleting all rows of
 | 
						|
    a table with the "count_changes" pragma turned on.</li>
 | 
						|
<li>Better error reporting when problems occur during the automatic
 | 
						|
    2.5.6 to 2.6.0 database format upgrade.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Jly 17 (2.6.0)} {
 | 
						|
<li>Change the format of indices to correct a design flaw the originated
 | 
						|
    with version 2.1.0.  <font color="red">*** This is an incompatible
 | 
						|
    file format change ***</font>  When version 2.6.0 or later of the
 | 
						|
    library attempts to open a database file created by version 2.5.6 or
 | 
						|
    earlier, it will automatically and irreversibly convert the file format.
 | 
						|
    <b>Make backup copies of older database files before opening them with
 | 
						|
    version 2.6.0 of the library.</b>
 | 
						|
    </li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Jly 7 (2.5.6)} {
 | 
						|
<li>Fix more problems with rollback.  Enhance the test suite to exercise
 | 
						|
    the rollback logic extensively in order to prevent any future problems.
 | 
						|
    </li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Jly 6 (2.5.5)} {
 | 
						|
<li>Fix a bug which could cause database corruption during a rollback.
 | 
						|
    This bugs was introduced in version 2.4.0 by the freelist
 | 
						|
    optimization of checking [410].</li>
 | 
						|
<li>Fix a bug in aggregate functions for VIEWs.</li>
 | 
						|
<li>Other minor changes and enhancements.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Jly 1 (2.5.4)} {
 | 
						|
<li>Make the "AS" keyword optional again.</li>
 | 
						|
<li>The datatype of columns now appear in the 4th argument to the
 | 
						|
    callback.</li>
 | 
						|
<li>Added the <b>sqlite_open_aux_file()</b> API, though it is still
 | 
						|
    mostly undocumented and untested.</li>
 | 
						|
<li>Added additional test cases and fixed a few bugs that those
 | 
						|
    test cases found.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Jun 24 (2.5.3)} {
 | 
						|
<li>Bug fix:  Database corruption can occur due to the optimization
 | 
						|
    that was introduced in version 2.4.0 (check-in [410]).  The problem
 | 
						|
    should now be fixed.  The use of versions 2.4.0 through 2.5.2 is
 | 
						|
    not recommended.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Jun 24 (2.5.2)} {
 | 
						|
<li>Added the new <b>SQLITE_TEMP_MASTER</b> table which records the schema
 | 
						|
    for temporary tables in the same way that <b>SQLITE_MASTER</b> does for
 | 
						|
    persistent tables.</li>
 | 
						|
<li>Added an optimization to UNION ALL</li>
 | 
						|
<li>Fixed a bug in the processing of LEFT OUTER JOIN</li>
 | 
						|
<li>The LIMIT clause now works on subselects</li>
 | 
						|
<li>ORDER BY works on subselects</li>
 | 
						|
<li>There is a new TypeOf() function used to determine if an expression
 | 
						|
    is numeric or text.</li>
 | 
						|
<li>Autoincrement now works for INSERT from a SELECT.</li>
 | 
						|
}
 | 
						|
 | 
						|
chng {2002 Jun 19 (2.5.1)} {
 | 
						|
<li>The query optimizer now attempts to implement the ORDER BY clause
 | 
						|
    using an index.  Sorting is still used if not suitable index is
 | 
						|
    available.</li>
 | 
						|
}
 | 
						|
 | 
						|
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 improvements 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 numerous 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 resolution 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 journaled 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 arbitrary 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 obscure 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>
 | 
						|
}
 | 
						|
footer {$Id:}
 |