@capacitor-community/sqlite
Capacitor community plugin for Native and Electron SQLite Databases. For Native and Electron platforms, databases could be encrypted with SQLCipher
npm i --save buffer
...
import { Buffer } from 'buffer';
...
private async readImage(db: SQLiteDBConnection, query: string, imageId: number) {
const retQuery = await db.query(query, [imageId]);
if(retQuery.values.length !==1 ) {
return Promise.reject(new Error("Blob Image query failed"));
}
if(retQuery.values[0].blob.length <= 0) {
return Promise.reject(new Error("Blob Image query blob length <= 0"));
}
const arr = new Uint8Array(retQuery.values[0].blob )
var myBlob = new Blob( [ arr ], { type: retQuery.values[0].type } );
const imageUrl: string = URL.createObjectURL( myBlob );
return imageUrl;
}
...
const query = `SELECT name, type, blob FROM blobs WHERE id = ? ;`;
const imageUrl: string = await this.readImage(db, query, imageId);
const imageEL: HTMLImageElement = document.querySelector('#image');
imageEL.src = imageUrl;
...
...
import { Buffer } from 'buffer';
...
const query = `SELECT name, type, blob FROM blobs WHERE id = ? ;`;
let retQuery: any = await db.query(query,[textId]);
if(retQuery.values.length !==1 ) {
return Promise.reject(new Error("Blob text query failed"));
}
if(retQuery.values[0].type !== "text") {
return Promise.reject(new Error("Blob text query not return the right type"));
}
const retText = (Buffer.from(retQuery.values[0].blob)).toString();
const myText = retText;
...
...
import { Buffer } from 'buffer';
...
private async readImage(db: SQLiteDBConnection, query: string, imageId: number) {
const retQuery = await db.query(query, [imageId]);
if(retQuery.values.length !==1 ) {
return Promise.reject(new Error("Blob Image query failed"));
}
if(retQuery.values[0].blob.length <= 0) {
return Promise.reject(new Error("Blob Image query blob length <= 0"));
}
const arr = new Uint8Array(retQuery.values[0].blob )
var myBlob = new Blob( [ arr ], { type: retQuery.values[0].type } );
const imageUrl: string = URL.createObjectURL( myBlob );
return imageUrl;
}
...
const query = `SELECT name, type, blob FROM blobs WHERE id = ? ;`;
imageUrl = await this.readImage(db, query, imageId);
const imageEL: HTMLImageElement = document.querySelector('#image');
imageEL.src = imageUrl;
...
import { Buffer } from 'buffer';
...
private async writeImage(db: SQLiteDBConnection, stmt: string, imagePath: string, name: string, type: string) {
const blob = await(await fetch(imagePath)).blob();
const imageBuffer = Buffer.from(new Uint8Array(await blob.arrayBuffer()));
const imgValues = [name,type, imageBuffer];
const ret = await db.run(stmt, imgValues);
if(ret.changes.changes !== 1) {
return Promise.reject(new Error('WriteImage failed'))
}
return ret.changes.lastId;
}
...
const imagePath = "YOUR_IMAGE_PATH/YOUR_IMAGE_NAME.png";
const stmt = "INSERT INTO blobs (name, type, blob) VALUES( ?,?,?);";
let imageId = await this.writeImage(db, stmt, imagePath, "Image1", "png");
...
...
import { Buffer } from 'buffer';
...
const textBuffer = Buffer.from('Hello, World!');
const stmt = "INSERT INTO blobs (name, type, blob) VALUES( ?,?,?);";
const values = ["test blob text", "text", textBuffer];
let ret: any = await db.run(stmt, values);
let textId = ret.changes.lastId;
...
import { Buffer } from 'buffer';
...
private async writeImage(db: SQLiteDBConnection, stmt: string, imagePath: string, name: string, type: string) {
const blob = await(await fetch(imagePath)).blob();
const imageBuffer = Buffer.from(new Uint8Array(await blob.arrayBuffer()));
const imgValues = [name,type, imageBuffer];
const ret = await db.run(stmt, imgValues);
if(ret.changes.changes !== 1) {
return Promise.reject(new Error('WriteImage failed'))
}
return ret.changes.lastId;
}
...
const imgBase64 = ""
;
const stmt = "INSERT INTO blobs (name, type, blob) VALUES( ?,?,?);";
const imageId = await this.writeImage(db, stmt, imgBase64, "feather", "base64");
...