AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Beschleunigungstips für SQLite unter Android erwünscht
Thema durchsuchen
Ansicht
Themen-Optionen

Beschleunigungstips für SQLite unter Android erwünscht

Ein Thema von sko1 · begonnen am 17. Mai 2017 · letzter Beitrag vom 19. Mai 2017
Antwort Antwort
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.487 Beiträge
 
Delphi 12 Athens
 
#1

AW: Beschleunigungstips für SQLite unter Android erwünscht

  Alt 17. Mai 2017, 14:12
Wenn deine Query auch mehrere SQL-Befehle gemeinsam als Skrip absenden kann, könnte das so schneller gehn:
Delphi-Quellcode:
 FDQuery.SQL.Text := 'BEGIN TRANSACTION;';
 // in "SQLList" müssen die einzelnen Statements bereits mit ';' abgeschlossen ein
 FDQuery.SQL.Add(SQLList.Text);
 FDQuery.SQL.Add('COMMIT;');
 FDQuery.ExecSQL;
http://docwiki.embarcadero.com/RADSt...tches_(FireDAC)

Geändert von Blup (17. Mai 2017 um 14:17 Uhr) Grund: Weil ich kann.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.867 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Beschleunigungstips für SQLite unter Android erwünscht

  Alt 17. Mai 2017, 14:22
Könnte in disem Fall (SQlite) stimmen. Im Allgemeinen dütfte die Variante per Parameter (prepared Statement) aber schneller sein.
Markus Kinzler
  Mit Zitat antworten Zitat
sko1

Registriert seit: 27. Jan 2017
601 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#3

AW: Beschleunigungstips für SQLite unter Android erwünscht

  Alt 17. Mai 2017, 14:27
Danke, danke, danke!

Jetzt habe ich ja erst mal eine Weile zu testen, die Variante mit dem Parameters habe ich glaube ich verstanden, da muss ich jedoch etliches Umbauen.

Daher wird der erste Test mal alle Inserts per SQL.Add reinpacken und mit einem ExecSQL abarbeiten sein, mal sehen ob das funktioniert.

Danke auch für den Hinweis, das Parameters[index] schneller ist wie ParamByName, ich hätte bestimmt erst letzteres probiert

Ciao
Stefan
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.008 Beiträge
 
Delphi 2009 Professional
 
#4

AW: Beschleunigungstips für SQLite unter Android erwünscht

  Alt 17. Mai 2017, 14:29
Optimierungstipp von https://stackoverflow.com/a/28188228/80901

* eine Transaktion verwenden

Michael Justin
  Mit Zitat antworten Zitat
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.487 Beiträge
 
Delphi 12 Athens
 
#5

AW: Beschleunigungstips für SQLite unter Android erwünscht

  Alt 17. Mai 2017, 15:38
Transaktion hat er doch schon per SQL-Befehl.
Zu viele Inserts in einer Transaktion können aber auch bremsend wirken.
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

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

AW: Beschleunigungstips für SQLite unter Android erwünscht

  Alt 17. Mai 2017, 16:49
Also ich mache das so... ca. 45000 Datensätze und 37 Felder. Dauert ca 18-25 Sekunden je nach Device. Der Source ist noch aus den Anfängen... Heute würde ich es auch anders machen...

Delphi-Quellcode:
 
          SQLConnection.Open;

          Felder := MakeFieldDef(FRecordDef);

          SQLQuery.SQL.Text := 'BEGIN;';
          SQLQuery.ExecSQL(true);
 
           while not(SQLReader.eof) do
            begin
              SQLReader.ReadSQLCrypt; // Lade die Daten aus einer verschlüsselten Datei

              inc(Count);

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

              D := SQLReader.GetSQLBytes;

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

          StatusProg('',100.0,SIndexWait); // 'Erzeuge Index, Bitte warten...'
          SQLQuery.SQL.Text := 'COMMIT;';
          SQLQuery.ExecSQL(true);

          SQLConnection.Close;
Mavarik
  Mit Zitat antworten Zitat
Daniel
(Co-Admin)

Registriert seit: 30. Mai 2002
Ort: Hamburg
13.920 Beiträge
 
Delphi 10.4 Sydney
 
#7

AW: Beschleunigungstips für SQLite unter Android erwünscht

  Alt 17. Mai 2017, 17:00
Die Array-DML von FireDAC könnte helfen. Sofern auf dem Gerät SQLite in Version >= 3.7.11 läuft, wird dieses Vorgehen auch von der DB unterstützt:

http://docwiki.embarcadero.com/RADSt..._DML_(FireDAC)
Daniel R. Wolf
mit Grüßen aus Hamburg
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

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

AW: Beschleunigungstips für SQLite unter Android erwünscht

  Alt 17. Mai 2017, 17:03
Die Array-DML von FireDAC könnte helfen. Sofern auf dem Gerät SQLite in Version >= 3.7.11 läuft, wird dieses Vorgehen auch von der DB unterstützt:

http://docwiki.embarcadero.com/RADSt..._DML_(FireDAC)
ggf. Aber auf einem Device ist eh alles RAM... Wenn man sich das Ganze mal mit Instruments anschaut (ok ist iOS) sieht man wie sich der Speicher auf und ab baut...
  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 23:35 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz