Awesome
SQLite3-WinRT
Async SQLite for (JavaScript) Windows Store apps.
Changelog
1.3.4
Support for blobs
This allows you to insert blobs into your database and read them back as BASE64 encoded values in your JSON result. See the blob example how to use it in your apps. If you need an IBuffer back from the db you can use CryptographicBuffer.DecodeFromBase64String.
1.1.2
Some minor API changes:
getLastInsertRowId()
function becomeslastInsertRowId
propertygetAutocommit()
function becomesautoCommit
propertygetLastError()
function becomeslastError
propertyenableSharedCache()
function becomessharedCache
property
1.1.0
This version introduces a breaking API change along with some enhancements:
runAsync
no longer returns the database for chained calls. Instead it will now return the number of rows affected by the executed SQL statement.- A special collation sequence,
WINLOCALE
is introduced. It uses the sorting behaviour of the currently active system locale. The locale can be overridden by settingdb.collationLanguage
. - We also now implemented a
regexp
function based on the STL (TR1) regex functionality. You can now use theREGEXP
operator, see the SQLite documentation for further information.
As usual, you should look at our unit tests if you are unsure how to use this new functionality.
Status
We finally consider SQLite3-WinRT ready for production use and it is already being used by certified apps published in the Windows Store including, of course our own application. Support for BLOBs and an API for transaction management are still on our to-do list - unfortunately with a very low priority. Feedback and contributions are highly appreciated, feel free to open issues or pull requests on GitHub.
Setup
SQLite3-WinRT consists of two parts, a WinRT component named SQLite3Component and a JavaScript namespace called SQLite3JS that builds upon the SQLite3Component.
Therefore, in order to use SQLite3JS in a JavaScript app, the
SQLite3Component project SQLite3Component\SQLite3Component.vcxproj
must be
added to the app's solution using FILE > Add > Existing Project....
A reference to SQLite3Component must be added to the app's project using
PROJECT > Add Reference.... Now, the SQLite3JS source
SQLite3JS\js\SQLite3.js
can be used in the app's project.
Note for users of Visual Studio 2012 Express: To compile the WinRT component successfully, please install the Windows SDK.
Usage
The SQLite3JS namespace provides an async JavaScript API for SQLite. It is built
around the Database
object that can be obtained using SQLite3JS.openAsync()
.
The API was inspired by node-sqlite3.
Example
var dbPath = Windows.Storage.ApplicationData.current.localFolder.path + '\\db.sqlite';
SQLite3JS.openAsync(dbPath)
.then(function (db) {
return db.runAsync('CREATE TABLE Item (name TEXT, price REAL, id INT PRIMARY KEY)')
.then(function () {
return db.runAsync('INSERT INTO Item (name, price, id) VALUES (?, ?, ?)', ['Mango', 4.6, 123]);
})
.then(function () {
return db.eachAsync('SELECT * FROM Item', function (row) {
console.log('Get a ' + row.name + ' for $' + row.price);
});
})
.then(function () {
db.close();
});
});
License
Copyright (c) 2012,2013 doo GmbH
Licensed under the MIT License, see LICENSE file.