npm install @sqlitecloud/drivers
You also have to install Peer Dependencies
npm install @sqlitecloud/drivers react-native-tcp-socket react-native-quick-base64
React Native run iOS
cd ios && pod install && cd .. && npm run ios
React Native run Android (without ./ in Windows)
cd android && ./gradlew clean build && cd .. && npm run android
Expo run iOS
npx expo prebuild && npx expo run:ios
Expo run Android
npx expo prebuild && npx expo run:android
import { Database } from '@sqlitecloud/drivers'
let database = new Database('sqlitecloud://user:[email protected]:8860/chinook.sqlite')
// or use sqlitecloud://xxx.sqlite.cloud:8860?apikey=xxxxxxx
let name = 'Breaking The Rules'
let results = await database.sql`SELECT * FROM tracks WHERE name = ${name}`
// => returns [{ AlbumId: 1, Name: 'Breaking The Rules', Composer: 'Angus Young... }]
Use Database.sql to execute prepared statements or plain SQL queries asynchronously. This method returns an array of rows for SELECT queries and supports the standard syntax for UPDATE, INSERT, and DELETE.
We aim for full compatibility with the established sqlite3 API, with the primary distinction being that our driver connects to SQLiteCloud databases. This allows you to migrate your SQLite to the cloud while continuing to use your existing codebase.
The package is developed entirely in TypeScript and is fully compatible with JavaScript. It doesn't require any native libraries. This makes it a straightforward and effective tool for managing cloud-based databases in a familiar SQLite environment.
import { Database } from '@sqlitecloud/drivers'
import { PubSub, PUBSUB_ENTITY_TYPE } from '@sqlitecloud/drivers/lib/drivers/pubsub'
let database = new Database('sqlitecloud://user:[email protected]:8860/chinook.sqlite')
// or use sqlitecloud://xxx.sqlite.cloud:8860?apikey=xxxxxxx
const pubSub: PubSub = await database.getPubSub()
await pubSub.listen(PUBSUB_ENTITY_TYPE.TABLE, 'albums', (error, results, data) => {
if (results) {
// Changes on albums table will be received here as JSON object
console.log('Received message:', results)
}
})
await database.sql`INSERT INTO albums (Title, ArtistId) values ('Brand new song', 1)`
// Stop listening changes on the table
await pubSub.unlisten(PUBSUB_ENTITY_TYPE.TABLE, 'albums')
Pub/Sub is a messaging pattern that allows multiple applications to communicate with each other asynchronously. In the context of SQLiteCloud, Pub/Sub can be used to provide real-time updates and notifications to subscribed applications whenever data changes in the database or it can be used to send payloads (messages) to anyone subscribed to a channel.
Pub/Sub Documentation: https://docs.sqlitecloud.io/docs/pub-sub
Check out all the supported platforms with related examples here!
How do I deploy SQLite in the cloud?
https://sqlitecloud.io
How do I connect SQLite cloud with Javascript?
https://sqlitecloud.github.io/sqlitecloud-js/
How can I contribute or suggest features?
https://github.com/sqlitecloud/sqlitecloud-js/issues