Como trabalhar com o SQLite no react native usando expo?

expo-sqlitedá ao seu aplicativo acesso a um banco de dados que pode ser consultado por meio de uma API semelhante ao WebSQL . O banco de dados persiste durante as reinicializações do seu aplicativo.

Compatibilidade de plataforma

  • Dispositivo Android
  • Emulador Android
  • Dispositivo iOS
  • Simulador iOS Para utiliza-lo em seu projecto expo, em primeiro lugar deverá instalar a dependência em seu projecto usando o comando: npx expo install expo-sqlite Após isso faça a importação da biblioteca import * as SQLite from 'expo-sqlite';

Importando um banco de dados existente

Para abrir um novo banco de dados SQLite usando um .dbarquivo existente que você já possui, siga as etapas abaixo:

  1. Instalação expo-file-systeme expo-assetmódulos: npx expo install expo-file-system expo-asset
  2. Crie um arquivo metro.config.js na raiz do seu projeto com o seguinte conteúdo para incluir extensões de ativos extras :
const { getDefaultConfig } = require('expo/metro-config');

const defaultConfig = getDefaultConfig(__dirname);

defaultConfig.resolver.assetExts.push('db');

module.exports = defaultConfig;
  1. Use a seguinte função (ou similar) para abrir seu banco de dados:
async function openDatabase(pathToDatabaseFile: string): Promise<SQLite.WebSQLDatabase> {
  if (!(await FileSystem.getInfoAsync(FileSystem.documentDirectory + 'SQLite')).exists) {
    await FileSystem.makeDirectoryAsync(FileSystem.documentDirectory + 'SQLite');
  }
  await FileSystem.downloadAsync(
    Asset.fromModule(require(pathToDatabaseFile)).uri,
    FileSystem.documentDirectory + 'SQLite/myDatabaseName.db'
  );
  return SQLite.openDatabase('myDatabaseName.db');
}

Logo apos isso não se esqueça de instânciar o seu banco de dadosconst db = SQLite.openDatabase('dbName', version);

Gostou?

é possivel criar um backup do banco em zip para uma pasta especifica do android por exemplo downloads ?