AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

FMX Android Datenimport

Ein Thema von Devil1925 · begonnen am 18. Aug 2016 · letzter Beitrag vom 18. Aug 2016
Antwort Antwort
Benutzerbild von Devil1925
Devil1925

Registriert seit: 20. Nov 2015
Ort: Saerbeck
236 Beiträge
 
Delphi 10.3 Rio
 
#1

FMX Android Datenimport

  Alt 18. Aug 2016, 08:31
Hallo,
vielleicht hat ja einer von euch eine Idee/einen Ansatz wie ich folgenden Datenimport beschleunigen kann:

Hier muss ich Daten aus einer MSSQL-Datenbank auf ein Android Gerät in eine SQLITE Datenbank einspielen.
Delphi-Quellcode:
  Q_SQLITE.Close;
  Q_SQLITE.SQL.Text := 'Select Spalte1, Spalte2, Spalte3 from Tabelle';
  Q_SQLITE.Open;
  Q_MSSQL.Close;
  Q_MSSQL.SQL.Text := 'Select Spalte1, Spalte2, Spalte3 from Tabelle';
  Q_MSSQL.Open;
  Q_MSSQL.First;

  while not Q_MSSQL_Import.Eof do
    begin
      Q_SQLITE_Import.Append;

        for i := 0 to Q_MSSQL_Import.Fields.Count - 1 do
          begin
            Q_SQLITE_Import.FieldByName(Q_MSSQL_Import.Fields[i].FullName).Value :=
                Q_MSSQL_Import.FieldByName(Q_MSSQL_Import.Fields[i].FullName).Value;
          end;
      Q_SQLITE_Import.Post;
      Q_MSSQL_Import.Next;
    end;
Diese Version des Datenimports ist bei kleineren Datenmengen durchaus in Ordnung. Wenn dann allerdings 5000+ Datensätze importiert werden sollen, Dauert es dann doch schon sehr lange.
Philipp
Höllische Grüße
Devil
Meistens sitzt das Problem vor dem Bildschirm! - Leider bin das oftmals ich.
  Mit Zitat antworten Zitat
Rollo62

Registriert seit: 15. Mär 2007
4.093 Beiträge
 
Delphi 12 Athens
 
#2

AW: FMX Android Datenimport

  Alt 18. Aug 2016, 10:20
FireDac Array DML ?
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.143 Beiträge
 
Delphi 10.3 Rio
 
#3

AW: FMX Android Datenimport

  Alt 18. Aug 2016, 10:54
Hier muss ich Daten aus einer MSSQL-Datenbank auf ein Android Gerät in eine SQLITE Datenbank einspielen.
Du hast aber vom Device eine Connection zum MSSQL Server, richtig?
  Mit Zitat antworten Zitat
Benutzerbild von Devil1925
Devil1925

Registriert seit: 20. Nov 2015
Ort: Saerbeck
236 Beiträge
 
Delphi 10.3 Rio
 
#4

AW: FMX Android Datenimport

  Alt 18. Aug 2016, 11:02
@Rollo62: Werde ich mir mal ansehen!
@Mavarik: Ja, Ich habe sowohl eine Connection zum MSSQL-Server als auch zur SQLITE Datenbank.
Philipp
Höllische Grüße
Devil
Meistens sitzt das Problem vor dem Bildschirm! - Leider bin das oftmals ich.
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.143 Beiträge
 
Delphi 10.3 Rio
 
#5

AW: FMX Android Datenimport

  Alt 18. Aug 2016, 11:20
@Mavarik: Ja, Ich habe sowohl eine Connection zum MSSQL-Server als auch zur SQLITE Datenbank.
ok das Ding mit dem Array ist eine Möglichkeit... Ich habe keine Verbindung zur Datenbank und erzeuge mir daher (wie ein Backup) fertige SQL-Insert-String. So brauche keine 30 Zuweisungen, wenn meine Tabelle 30 Spalten hat...


Und dann mache ich es so:
Delphi-Quellcode:
          SQLQuery.SQL.Text := 'BEGIN;';
          SQLQuery.ExecSQL(true);
          StatusProg('',0.0,'0.00%');

          while not(SQLReader.eof) do
            begin
              SQLReader.ReadSQLCrypt;

              inc(Count);

              if (Count mod 100) = 0 then
                StatusProg('',100.0 / MaxSize * SQLReader.Position,FloattoStrF(100.0 / MaxSize * SQLReader.Position,ffFixed,7,2)+'%');

              DataLine := SQLReader.GetSQLBytes;

              SQLQuery.SQL.Text := 'INSERT INTO '+FTableName+' ('+Felder+') VALUES (0,'+Dataline+PostFields+');';
              try
                SQLQuery.ExecSQL(false);
              except
                StatusProg('EXCEPTION',0,'');
              end;
            end;

          StatusProg('',100.0,SIndexWait);
          SQLQuery.SQL.Text := 'COMMIT;';
          SQLQuery.ExecSQL(true);

          SQLConnection.Close;
        finally
          ArcFree(SQLReader,'SQLReader');
        end;
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:07 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz