wxSQLite3 4.10.2
Loading...
Searching...
No Matches
wxSQLite3

What is wxSQLite3?

wxSQLite3 is a C++ wrapper around the public domain SQLite 3.x database and is specifically designed for use in programs based on the wxWidgets library.

Several solutions already exist to access SQLite databases. To name just a few:

  • wxSQLite : This is a wxWidgets wrapper for version 2.8.x of SQLite. SQLite version 3.x has a lot more features - which are not supported by this wrapper.
  • CppSQLite : Not wxWidgets specific, but with (partial) support for the newer version 3.x of SQLite.
  • DatabaseLayer : This is a database abstraction providing a JDBC-like interface to database I/O. In the current version SQLite3, PostgreSQL, MySQL, Firebird, and ODBC database backends are supported.

The component wxSQLite3 was inspired by all three mentioned SQLite wrappers. wxSQLite3 does not try to hide the underlying database, in contrary almost all special features of the SQLite3 version 3.x are supported, like for example the creation of user defined scalar or aggregate functions.

Since SQLite stores strings in UTF-8 encoding, the wxSQLite3 methods provide automatic conversion between wxStrings and UTF-8 strings. The methods ToUTF8 and FromUTF8 of the wxString class (available since wxWidgets 2.8.4) are used for the conversion. Special care has to be taken if external administration tools are used to modify the database contents, since not all of these tools operate in Unicode or UTF-8 mode.

Note
With the release of SQLite version 3.32.0 on May 22, 2020 critical changes to the public SQLite code finally took officially effect, although they weren't officially announced. They were introduced on Feb 7, 2020: "Simplify the code by removing the unsupported and undocumented SQLITE_HAS_CODEC compile-time option". Since August 2020 a new implementation of an encryption extension, capable of supporting SQLite version 3.32.0 and later, is available as a separate project, SQLite3 Multiple Ciphers. Starting with the release of wxSQLite3 4.6.0 this new implementation will be used.

Version history

4.10.2 - January 2025

Upgrade to SQLite3 Multiple Ciphers version 2.0.2 (SQLite version 3.48.0)

4.10.1 - January 2025

Upgrade to SQLite3 Multiple Ciphers version 2.0.1 (SQLite version 3.47.2)
Fixed issue #120 - crashes on some Linux systems due to illegal instruction exceptions related to the code of the new cipher scheme AEGIS

4.10.0 - December 2024

Upgrade to SQLite3 Multiple Ciphers version 2.0.0 (SQLite version 3.47.2)
Removed User Authentication extension
Added new cipher scheme AEGIS

4.9.12 - October 2024

Upgrade to SQLite3 Multiple Ciphers version 1.9.0 (SQLite version 3.47.0)

4.9.11 - June 2024

Upgrade to SQLite3 Multiple Ciphers version 1.8.6 (SQLite version 3.46.0)

4.9.10 - March 2024

Upgrade to SQLite3 Multiple Ciphers version 1.8.4 (SQLite version 3.45.2)
Disable user authentication extension in build files by default

4.9.9 - January 2024

Upgrade to SQLite3 Multiple Ciphers version 1.8.2 (SQLite version 3.45.0)

4.9.8 - November 2023

Upgrade to SQLite3 Multiple Ciphers version 1.8.0 (SQLite version 3.44.1)
Added new cipher scheme Ascon-128 (Lightweight Authenticated Encryption)

4.9.7 - November 2023

Upgrade to SQLite3 Multiple Ciphers version 1.7.4 (SQLite version 3.44.0)
Prevent crashes due to uninitialized cipher tables (issue #113)

4.9.6 - October 2023

Upgrade to SQLite3 Multiple Ciphers version 1.7.0 (SQLite version 3.43.1)

4.9.5 - September 2023

Upgrade to SQLite3 Multiple Ciphers version 1.6.5 (SQLite version 3.43.1)

4.9.4 - May 2023

Upgrade to SQLite3 Multiple Ciphers version 1.6.3 (SQLite version 3.42.0)

4.9.3 - March 2023

Upgrade to SQLite3 Multiple Ciphers version 1.6.1 (SQLite version 3.41.1)

4.9.2 - February 2023

Upgrade to SQLite3 Multiple Ciphers version 1.6.0 (SQLite version 3.41.0)
Enhanced method wxSQLite3Database::Open allowing to set the VFS to be used
Added method wxSQLite3Database::IsInterrupted

4.9.1 - November 2022

Upgrade to SQLite3 Multiple Ciphers version 1.5.4 (SQLite version 3.40.0)

4.9.0 - September 2022

Upgrade to SQLite3 Multiple Ciphers version 1.5.3 (SQLite version 3.39.3)

4.8.2 - July 2022

Upgrade to SQLite3 Multiple Ciphers version 1.4.6 (SQLite version 3.39.1)

4.8.1 - May 2022

Upgrade to SQLite3 Multiple Ciphers version 1.4.3 (SQLite version 3.38.5)

4.8.0 - April 2022

Upgrade to SQLite3 Multiple Ciphers version 1.4.2 (SQLite version 3.38.3)

4.7.9 - April 2022

Upgrade to SQLite3 Multiple Ciphers version 1.3.10 (SQLite version 3.38.2)

4.7.8 - March 2022

Upgrade to SQLite3 Multiple Ciphers version 1.3.9 (SQLite version 3.38.1)

4.7.7 - February 2022

Upgrade to SQLite3 Multiple Ciphers version 1.3.8 (SQLite version 3.38.0)

4.7.6 - January 2022

Upgrade to SQLite3 Multiple Ciphers version 1.3.7 (SQLite version 3.37.2)

4.7.5 - November 2021

Upgrade to SQLite3 Multiple Ciphers version 1.3.5 (SQLite version 3.37.0)

4.7.4 - July 2021

Upgrade to SQLite3 Multiple Ciphers version 1.3.4 (SQLite version 3.36.0)

4.7.3 - June 2021

Upgrade to SQLite3 Multiple Ciphers version 1.3.3 (SQLite version 3.36.0)

4.7.2 - May 2021

Upgrade to SQLite3 Multiple Ciphers version 1.3.2 (SQLite version 3.35.5)

4.7.1 - April 2021

Upgrade to SQLite3 Multiple Ciphers version 1.3.1 (SQLite version 3.35.5)

4.7.0 - April 2021

Upgrade to SQLite3 Multiple Ciphers version 1.3.0 (SQLite version 3.35.5)

4.6.10 - April 2021

Upgrade to SQLite3 Multiple Ciphers version 1.2.5 (SQLite version 3.35.5)

4.6.9 - April 2021

Upgrade to SQLite3 Multiple Ciphers version 1.2.4 (SQLite version 3.35.4)

4.6.8 - March 2021

Upgrade to SQLite3 Multiple Ciphers version 1.2.3 (SQLite version 3.35.3)

4.6.7 - March 2021

Upgrade to SQLite3 Multiple Ciphers version 1.2.2 (SQLite version 3.35.2)

4.6.6 - March 2021

Upgrade to SQLite3 Multiple Ciphers version 1.2.1 (SQLite version 3.35.1)

4.6.5 - March 2021

Upgrade to SQLite3 Multiple Ciphers version 1.2.0 (SQLite version 3.35.0)
Enabled new SQLite Math Extension
Fixed a memory leak in method wxSQLite3Database::GetTable
Adjusted build files (DLL builds with MinGW/GCC used wrong DLL file extension)

4.6.4 - December 2020

Upgrade to SQLite3 Multiple Ciphers version 1.1.3
Adjusted autotool build files to enable AES hardware support if available

4.6.3 - December 2020

Upgrade to SQLite3 Multiple Ciphers version 1.1.2
Adjusted build files for MinGW

4.6.2 - December 2020

Upgrade to SQLite3 Multiple Ciphers version 1.1.1
Upgrade to SQLite version 3.34.0
Added method wxSQLite3Database::QueryTransactionState

4.6.1 - October 2020

Added SQLite VSV extension (Variably Separated Values)

4.6.0 - August 2020

Use SQLite encryption extension "SQLite3 Multiple Ciphers"
Upgrade to SQLite version 3.33.0
Added support for System.Data.SQLite's RC4 encryption

4.5.1 - January 2020

Upgrade to SQLite version 3.31.1

4.5.0 - January 2020

Upgrade to SQLite version 3.31.0
Modified API for wxSQLite3Database::CreateFunction methods

4.4.8 - October 2019

Upgrade to SQLite version 3.30.1
Adjusted encryption extension to support SQLite's shared cache mode

4.4.7 - October 2019

Upgrade to SQLite version 3.30.0

4.4.6 - September 2019

Fixed missing cipher application in method wxSQLite3Database::ReKey

4.4.5 - August 2019

Fixed broken compatibility with wxWidgets 2.8.12

4.4.4 - August 2019

Upgrade to SQLite version 3.29.0
Added SQLite logging support
Added build support for VS2019
Added CMake support (PR #63)
Updated build files to overcome problems with static builds (issue #73)
Eliminated duplication of error messages for different wxWidgets builds (PR #64)
Fixed missing call to progress callback in wxSQLite3Database::Restore (PR #66)
Fixed issue #58 with silently failing wxSQLite3Transaction::Commit method
Fixed issue with named collections which could result in crashes (PR #59)

4.4.3 - May 2019

Upgrade to SQLite version 3.28.0

4.4.2 - February 2019

Upgrade to SQLite version 3.27.2

4.4.1 - February 2019

Upgrade to SQLite version 3.27.1

4.4.0 - December 2018

Upgrade to SQLite version 3.26.0
Added support for the SQLCipher 4 database format

4.3.0 - November 2018

Upgrade to SQLite version 3.25.3
Adjusted encryption extension to support cipher configuration via database URI

4.2.0 - October 2018

Added method wxSQLite3Database::GetKeySalt to access the key salt of encrypted databases
Fixed memory leaks in methods wxSQLite3ResultSet::GetExpandedSQL and wxSQLite3Statement::GetExpandedSQL
Adjusted encryption extension to support raw key (and salt) for the ChaCha20 (sqleet) encryption scheme

4.1.1 - October 2018

Upgrade to SQLite version 3.25.2

4.1.0 - September 2018

Upgrade to SQLite version 3.25.1
Added support for SQL window functions
Adjusted encryption extension to check for matching page sizes on rekeying a database

4.0.4 - June 2018

Upgrade to SQLite version 3.24.0

4.0.3 - April 2018

Adjusted encryption extension to better support the SQLite backup API

4.0.2 - April 2018

Upgrade to SQLite version 3.23.1

4.0.1 - April 2018

Fixed a bug in the rekeying function of the encryption extension

4.0.0 - April 2018

Introduced multi-cipher support at runtime
Added methods for attaching/detaching databases
Cleaned up code using statement buffers
Improved constness of methods
Upgrade to SQLite version 3.23.0

3.5.9 - January 2018

Upgrade to SQLite version 3.22.0

3.5.8 - November 2017

Upgrade to SQLite version 3.21.0

3.5.7 - September 2017

Upgrade to SQLite version 3.20.1

3.5.6 - August 2017

Upgrade to SQLite version 3.20.0
Added support for persistent prepared statements
Added support for binding pointers (new SQLite pointer-binding interface)
Added several SQLite extensions (csv, sha3, carray, fileio, series) for the included SQLite library
Modified build files to expose the parameter SQLITE_MAX_ATTACHED to allow easier adjustment of the maximum number of attached databases

3.5.5 - June 2017

Upgrade to SQLite version 3.19.3

3.5.4 - June 2017

Upgrade to SQLite version 3.19.2

3.5.3 - March 2017

Upgrade to SQLite version 3.18.0
Minor modification to wxsqlite3.pc.in to fix issue with pkgconfig tool

3.5.2 - March 2017

Upgrade to SQLite version 3.17.0
Fixed minor issue in SQLite encryption extension related to symbol SQLITE_DEBUG
Modified build system for GNU make (support monolithic wxWidgets build)

3.5.1 - February 2017

Added version information as Windows resource for DLL builds on Windows
Cleaned up premake5 build files for Visual C++ (corrected debug environment settings)
Resolved wxWidgets library dependencies for Visual C++ using wxWidgets' special setup.h for MSVC

3.5.0 - January 2017

Upgrade to SQLite version 3.16.2
SQLite3 library now integrated part of wxSQLite3
Build system overhauled
Added Travis Continuous Integration

3.4.1 - October 2016

Upgrade to SQLite version 3.15.0

3.4.0 - August 2016

Upgrade to SQLite version 3.14.1
Added method wxSQLite3Statement::GetExpandedSQL
Added method wxSQLite3ResultSet::GetExpandedSQL
Started to modify the build system to compile and statically link the SQLite3 library together with wxSQLite3
Added the CSV extension module as part of the SQLite3 library with encryption extension

3.3.1 - April 2016

Upgrade to SQLite version 3.12.1
Added method wxSQLite3Database::GetSystemErrorCode

3.3.0 - December 2015

Upgrade to SQLite version 3.9.2
(SQLite amalgamation source adjusted to fix problem with user authentication module)

3.2.1 - March 2015

Upgrade to SQLite version 3.8.8.3
Fixed a bug in method GetParamName

3.2.0 - December 2014

Upgrade to SQLite version 3.8.7.4
Added support for the SQLite user authentication module

3.1.1 - June 2014

Upgrade to SQLite version 3.8.5

3.1.0 - May 2014

Upgrade to SQLite version 3.8.4.3
Added flag isDeterministic to method wxSQLite3Database::CreateFunction
Added new GUI sample
Changed implementation of encryption extension (see Readme file in sqlite3 subfolder)

3.0.6 - December 2013

Upgrade to SQLite version 3.8.2

3.0.5 - September 2013

Upgrade to SQLite version 3.8.0.2
Added support for setting the temporary directory for SQLite on Windows

3.0.4 - August 2013

Upgrade to SQLite version 3.8.0
Added support for querying performance characteristics of prepared statements

3.0.3 - March 2013

Upgrade to SQLite version 3.7.16

3.0.2 - December 2012

Upgrade to SQLite version 3.7.15.1
Corrected an internal SQLite data structure to avoid compile time warnings
Changed method wxSQLite3Exception::ErrorCodeAsString to return the error messages provided by SQLite

3.0.1 - November 2012

Upgrade to SQLite version 3.7.14.1
Cleaned up and optimized Finalize methods
Modified wxSQLite3Database::Close to avoid potential memory leaks
Added method wxSQLite3Database::GetWrapperVersion
Added method wxSQLite3Database::IsReadOnly
Added method wxSQLite3Statement::BindUnixDateTime
Added method wxSQLite3ResultSet::GetUnixDateTime
Added method wxSQLite3ResultSet::GetAutomaticDateTime
Fixed a potential memory leak in method wxSQLite3Database::ExecuteUpdate
Added a wxsqlite3.pc file on request of the Fedora Project developers
Replaced assert by wxASSERT in wxSQLite3Transaction constructor

3.0.0 - January 2012

Upgrade to SQLite version 3.7.10
Added method wxSQLite3Database::Vacuum
Added method wxSQLite3Database::GetDatabaseFilename
Added method wxSQLite3Database::ReleaseMemory
Added method wxSQLite3ResultSet::CursorMoved
Added method wxSQLite3Statement::IsBusy
Fixed a bug in method operator= of wxSQLite3StringCollection causing an endless recursion on assignment
Dropped the concept of SQLite3 pointer ownership in favor of reference counted pointers allowing much more flexible use of wxSQLite3 classes
Modified SQLite3 encryption extension (defining int64 datatype for SHA2 algorithm)
Dropped dbadmin sample from build files
Added Premake support for SQLite3 library with encryption support and for wxSQLite3 (experimental)

2.1.3 - August 2011

Corrected default behavior for attached databases in case of an encrypted main database. (Now the attached database uses the same encryption key as the main database if no explicit key is given. Previously the attached database remained unencrypted.)
Added an optional progress callback for methods Backup and Restore
Added method SetBackupRestorePageCount to set the number of pages to be copied in one cycle of the backup/restore process

2.1.2 - July 2011

Upgrade to SQLite version 3.7.7.1
Modified wxSQLite3Transaction to make it exception safe

2.1.1 - April 2011

Upgrade to SQLite version 3.7.6.1
Added convenience method wxSQLite3Statement::ExecuteScalar
Changed write-ahead log checkpoint method to new version (v2)

2.1.0 - March 2011

Upgrade to SQLite version 3.7.5
Added wxSQLite+, a database administration application written by Fred Cailleau-Lepetit, as a GUI sample for wxSQLite3. Minor adjustments were applied to make wxSQLite+ compatible with wxWidgets 2.9.x. Please note that wxSQLite+ is under GPL license.

2.0.2 - December 2010

Upgrade to SQLite version 3.7.4
Added support for rebinding a BLOB object to a new row
Added support for determining if an SQL statement writes the database

2.0.1 - October 2010

Upgrade to SQLite version 3.7.3
Added parameter transferStatementOwnership to method wxSQLite3Statement::ExecuteQuery to allow using the returned result set beyond the life time of the wxSQLite3Statement instance
Eliminated the use of sqlite3_mprintf which caused linker problems when loading SQLite dynamically

2.0.0 - July 2010

Upgrade to SQLite version 3.7.0
Fixed a bug in class wxSQLite3ResultSet
Added support for SQLite's write-ahead log journal mode
Added support for named collections (see class wxSQLite3NamedCollection)
Changed UTF-8 string handling to use methods To/FromUTF8 of the wxString class (requires wxWidgets 2.8.4 or higher)
Compatible with wxWidgets 2.9.1

1.9.9 - March 2010

Upgrade to SQLite version 3.6.23
Fixed a bug when compiling for dynamic loading of SQLite
Added static methods for accessing the run-time library compilation options diagnostics
Added mathod FormatV to class wxSQLite3StatementBuffer

1.9.8 - February 2010

Upgrade to SQLite version 3.6.22
Fixed a bug when compiling without pre-compiled header support (by including wx/arrstr.h)

1.9.7 - November 2009

Upgrade to SQLite version 3.6.20
Added methods to query, enable or disable foreign key support

1.9.6 - September 2009

Upgrade to SQLite version 3.6.18
Added method to get the SQLite library source id
Added flags parameter to wxSQLite3Database::Open to allow additional control over the database connection (see http://www.sqlite.org/c3ref/open.html for further information)
Fixed a potential memory leak in wxSQLite3Statement class
Converted encryption extension from C++ to pure C to make it compatible with the SQLite amalgamation.

1.9.5 - February 2009

Upgrade to SQLite version 3.6.11
Added user defined function class for REGEXP operator.
Added support for SQLite backup/restore API, introduced with SQLite 3.6.11

1.9.4 - January 2009

Upgrade to SQLite version 3.6.10
Added support for savepoints, introduced with SQLite 3.6.8
Added method IsOk to the classes wxSQLite3Statement, wxSQLite3Table and wxSQLite3ResultSet, thus instances of these classes can be checked whether the associated SQLite database or statement are valid without throwing an exception.

1.9.3 - December 2008

Upgrade to SQLite version 3.6.7
Fixed a bug in method wxSQLite3Table::GetDouble (conversion from string to double failed in non-US locales)
Build system upgraded using Bakefile 0.2.5

1.9.2 - November 2008

Upgrade to SQLite version 3.6.6
Added RAII transaction class (see docs for details)

1.9.1 - September 2008

Upgrade to SQLite version 3.6.2
Introduced own step counting for aggregate user functions since the sqlite3_aggregate_count function is now deprecated
Enhanced wxSQLite3Database::TableExists method to query an attached database for existence of a table or to query the main database and all attached databases

1.9.0 - July 2008

Upgrade to SQLite version 3.6.0
The optional key based encryption support has been adapted to support SQLite version 3.6.0.
Added static methods to initialize and shutdown the SQLite library.
Changed build system to support static library build against shared wxWidgets build on Linux.
Changed behaviour of wxSQLite3Database::Close method to finalize all not-finalized prepared statements.

1.8.5 - June 2008

Upgrade to SQLite version 3.5.9
Integration of the optional key based encryption support into SQLite has been made easier. Changes to original SQLite source files are no longer necessary.

1.8.4 - April 2008

Upgrade to SQLite version 3.5.8
Added support for accessing database limits
Changed method TableExists to check a table name case insensitive
Fixed several minor issues in the build files.

1.8.3 - January 2008

Added support for shared cache mode
Added support for access to original SQL statement for prepared statements (requires SQLite 3.5.3 or above)

1.8.2 - December 2007

Upgrade to SQLite version 3.5.4
Fixed a bug in wxSQLite3Database::Begin (wrong transaction type)

1.8.1 - November 2007

Fixed a bug in in wxSQLite3Database::Close (resetting flag m_isEncrypted)
Eliminated several compile time warnings (regarding unused parameters)
Fixed a compile time bug in wxSQLite3Database::GetBlob (missing explicit type cast)

1.8.0 - November 2007

Upgrade to SQLite version 3.5.2
Support for SQLite incremental BLOBs
Changed source code in the SQLite3 encryption extension to eliminate several warnings
Changed default wxWidgets version to 2.8.x
Adjusted sources for SQLite encryption support are included for all SQLite version from 3.3.1 up to 3.5.2
SQLite link libraries for MinGW on Windows are included
Added WXMAKINGLIB_WXSQLITE3 compile time option to support building wxSQLite3 as a static library while using the shared libraries of wxWidgets.

1.7.3 - May 2007

Upgrade to SQLite version 3.3.17

Fixed a bug in the SQLite3 encryption extension (MD5 algorithm was not aware of endianess on big-endian platforms, resulting in non-portable database files)

1.7.2 - February 2007

Upgrade to SQLite version 3.3.12
Support for loadable extensions is now optional Check for optional wxSQLite3 features at runtime wxSQLite3 API independent of optional features

1.7.1 - January 2007

Fixed a bug in the key based database encryption feature (The call to sqlite3_rekey in wxSQLite3Database::ReKey could cause a program crash, when used to encrypt a previously unencrypted database.)

1.7.0 - January 2007

Upgrade to SQLite version 3.3.10 (Attention: at least SQLite version 3.3.9 is required)
Added support for BLOBs as wxMemoryBuffer objects
Added support for loadable extensions
Optional support for key based database encryption

1.6.0 - July 2006

Added support for user defined collation sequences

1.5.3 - June 2006

Upgrade to SQLite version 3.3.6
Added support for optional SQLite meta data methods

1.5.2 - March 2006

Fixed a bug in wxSQLite3Database::Prepare
Added wxSQLite3Database::IsOpen for convenience

1.5.1 - February 2006

Upgrade to SQLite version 3.3.4 (wxMSW only)

1.5 - February 2006

Upgrade to SQLite version 3.3.3
Added support for commit, rollback and update callbacks

1.4.2 - November 2005

Optimized code for wxString arguments

1.4.1 - November 2005

Fixed a bug in wxSQLite3Database::TableExists,
Changed the handling of Unicode string conversion,
Added support for different transaction types

1.4 - November 2005

Optionally load the SQLite library dynamically at run time.

1.3.1 - November 2005

Corrected wxSQLite3ResultSet::GetInt64.
Added wxSQLite3Table::GetInt64

1.3 - October 2005

Added wxGTK build support

1.2 - October 2005

Corrected error in wxSQLite3Table::FindColumnIndex

1.1 - October 2005

Upgrade to SQLite version 3.2.7

1.0 - July 2005
First public release
Author
Ulrich Telle (ulrich DOT telle AT gmx DOT de)

Acknowledgments

Kudos to Fred Cailleau-Lepetit for developing wxSQLite+ as a sample demonstrating the wxWidgets components wxAUI and wxSQLite3 and for allowing it to be included in the wxSQLite3 distribution.

The following people have contributed to wxSQLite3:

  • Francesco Montorsi (enhancement of the build system)
  • Neville Dastur (enhancement of the method TableExists)
  • Tobias Langner (RAII class for managing transactions)
  • Deamhan (CMake support and various bug fixes)