Skip to content

Files

Latest commit

8d1a3c5 · Jun 15, 2023

History

History
156 lines (131 loc) · 5.68 KB

SQLiteBlob.md

File metadata and controls

156 lines (131 loc) · 5.68 KB


SQLite Blob DOCUMENTATION

@capacitor-community/sqlite

Capacitor community plugin for Native and Electron SQLite Databases. For Native and Electron platforms, databases could be encrypted with SQLCipher

Prerequisite

npm i --save buffer

Read a SQLite Blob

Image Blob

...
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;
...

Text Blob

...
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;
...

Base64 Image Blob

...
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;

Write a SQLite Blob

Image Blob

...
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");
...

Text Blob

...
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;
...

Base64 Image Blob

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");
  ...