Использование нескольких баз данных SQLite одновременно

У меня есть 2 базы данных SQLite, одна загружена с сервера (server.db), а другая используется в качестве хранилища на клиенте (client.db). Мне нужно выполнить различные запросы синхронизации в базе данных клиента, используя данные из базы данных сервера.

Например, я хочу удалить все строки в таблице client.db tRole и заново заполнить все строки в таблице server.db tRole.

Другой пример, я хочу удалить все строки в таблице client.db tFile, где fileID отсутствует в таблице server.db tFile.

В SQL Server вы можете просто добавить к таблице имя базы данных. Есть ли способ сделать это в SQLite с помощью Adobe Air?

«Невозможно сделать это на уровне базы данных». Как так? В SQLite есть ключевое слово attach, которое позволяет подключать другую базу данных. И ответ Тео показывает, что у Air, похоже, есть соответствующий вызов API. Есть ли какое-то различие, которое мне не хватает, когда вы конкретно говорите «с уровня базы данных»?

spaaarky21 09.05.2014 23:32
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
9
1
11 902
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

В Sqlite можно одновременно открывать несколько баз данных, но сомнительно, что это возможно при работе из Flex / AIR. В клиенте командной строки вы запускаете ATTACH DATABASE path/to/other.db AS otherDb, а затем можете ссылаться на таблицы в этой базе данных как otherDb.tableName, как в MySQL или SQL Server.

Tables in an attached database can be referred to using the syntax database-name.table-name.

ATTACH DATABASE documentation at sqlite.org

Ответ принят как подходящий

Я только что посмотрел на AIR SQL API, и там есть метод attach на SQLConnection, он выглядит именно так, как вам нужно.

Я не тестировал это, но согласно документации он должен работать:

var connection : SQLConnection = new SQLConnection();

connection.open(firstDbFile);
connection.attach(secondDbFile, "otherDb");

var statement : SQLStatement = new SQLStatement();

statement.connection = connection;
statement.text = "INSERT INTO main.myTable SELECT * FROM otherDb.myTable";
statement.execute();

В этом фрагменте кода могут быть ошибки, в последнее время я мало работал с AIR SQL API. Обратите внимание, что таблицы базы данных, открытые с помощью open, доступны с помощью main.tableName, любой подключенной базе данных можно вообще дать любое имя (otherDb в приведенном выше примере).

этот код может работать, он написан мной:

package lib.tools

import flash.utils.ByteArray;
import flash.data.SQLConnection;
import flash.data.SQLStatement;
import flash.data.SQLResult;
import flash.data.SQLMode; 
import flash.events.SQLErrorEvent;
import flash.events.SQLEvent;
import flash.filesystem.File;
import mx.core.UIComponent;
import flash.data.SQLConnection;

public class getConn {
    public var Conn:SQLConnection;

    public function getConn(database:Array) {       
        Conn = new SQLConnection();
        var Key:ByteArray = new ByteArray();
        Key.writeUTFBytes("Some16ByteString"); 
        Conn.addEventListener(SQLErrorEvent.ERROR, createError);
        var dbFile:File = File.applicationDirectory.resolvePath(database[0]);
        Conn.open(dbFile);
        if (database.length > 1) {
            for(var i:Number = 1; i < database.length; i++) {
                var DBname:String = database[i];
                Conn.attach(DBname.split("\.")[0], File.applicationDirectory.resolvePath(DBname));
            }
        }
        Conn.open(dbFile, SQLMode.CREATE, false, 1024, Key); 
    }

    private function createError(event:SQLErrorEvent):void {
        trace("Error code:", event.error.details);
        trace("Details:", event.error.message);
    }

    public function Rs(sql:Array):Object {
        var stmt:SQLStatement = new SQLStatement();
        Conn.begin();
        stmt.sqlConnection = Conn;
        try {
            for(var i:String in sql) {          
                stmt.text = sql[i]; 
                stmt.execute();
            }
            Conn.commit();
        } catch(error:SQLErrorEvent) {
            createError(error);
            Conn.rollback();
        };
        var result:Object =stmt.getResult();
        return result;
    }
}

Другие вопросы по теме