data:image/s3,"s3://crabby-images/e4483/e4483fe06b1b8573d8d0b6ae07e4a8ea96c6c69b" alt="Android remote sqlite database"
Android remote sqlite database download#
Inside the downloadDatabase we download the JSON file from the beginning, make sure the JSON is valid for the import and then import the whole data into our SQLite database (or better, the database will actually be created with that name). Now go ahead and change the app/services/ to:Īwait CapacitorSQLite. So within the setupDatabase we either start the download and import, or if we already did it before we can directly open the database (based on the name we stored).Īdditionally I added a BehaviorSubject so we can subscribe to the database stead and not perform any queries before it’s ready. This is just a very rough idea in here, it really depends on your case: Do you want to get the latest data on every app start? Do you just need the remote data once to seed the app? Think about what you need inside your app and then build out the logic for your needs.
data:image/s3,"s3://crabby-images/473c9/473c90764ee2602cbad54ce09ad3df3d0a7212b4" alt="android remote sqlite database android remote sqlite database"
data:image/s3,"s3://crabby-images/f27a4/f27a48338fc3bf57f911afb485c9d5939ee821e6" alt="android remote sqlite database android remote sqlite database"
data:image/s3,"s3://crabby-images/f0b5b/f0b5b8f1731eb3240c8b9e5874071b8b56d87dd5" alt="android remote sqlite database android remote sqlite database"
I’ve also added a bit of logic to store the name of the database (retrieved from the previous JSON file) inside Capacitor Storage, and also keep track whether we have already synced the initial data. Now our app can pull in that data and seed the initial SQLite database! Building a Database Serviceīefore we dive into the pages, let’s create the logic for the app upfront.īefore you can actually use the database, you should check whether you are running on Android, since you need to request permissions in that case!
data:image/s3,"s3://crabby-images/e4483/e4483fe06b1b8573d8d0b6ae07e4a8ea96c6c69b" alt="Android remote sqlite database"