AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken MyDac Table mit Open und FetchAll
Thema durchsuchen
Ansicht
Themen-Optionen

MyDac Table mit Open und FetchAll

Ein Thema von Edelfix · begonnen am 11. Mär 2025 · letzter Beitrag vom 12. Mär 2025
Antwort Antwort
Edelfix

Registriert seit: 6. Feb 2015
Ort: Stadtoldendorf
220 Beiträge
 
Delphi 10.4 Sydney
 
#1

MyDac Table mit Open und FetchAll

  Alt 11. Mär 2025, 12:32
Datenbank: MariaDB • Version: 10.5.11 • Zugriff über: MyDac
Hallo,
es geht sich um folgendes Problem. Ich habe in einer MariaDB Tabelle sehr viele Datensätze.
Der Open Befehl von der TMyTable Komponente braucht 6 Sekunden bis Daten angezeigt werden. Deswegen habe ich die Option FetchAll auf false gestellt.
So weit so gut.

Wenn ich jetzt aber mit Close die Table schließen möchte kommt jedes Mal eine Exception.
Exception-Klasse EMySqlException mit Meldung 'Lost connection to MySQL server during query'.

Wie schließe ich die Table ohne eine Exception zu bekommen?
  Mit Zitat antworten Zitat
Edelfix

Registriert seit: 6. Feb 2015
Ort: Stadtoldendorf
220 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: MyDac Table mit Open und FetchAll

  Alt 11. Mär 2025, 15:00
Ist wahrscheinlich ein Defekt in der Komponente. Habe bei Devart ein Ticket erstellt.
  Mit Zitat antworten Zitat
Benutzerbild von blawen
blawen

Registriert seit: 1. Dez 2003
Ort: Luterbach (CH)
691 Beiträge
 
Delphi 12 Athens
 
#3

AW: MyDac Table mit Open und FetchAll

  Alt Gestern, 07:40
Kann es sein, dass dazwischen zuviel Zeit vergeht (Timeout)? Falls ja, würde ich all paar Minuten mit einer zweiten Querry eine Refresh Abfrage starten.
Roland
  Mit Zitat antworten Zitat
Edelfix

Registriert seit: 6. Feb 2015
Ort: Stadtoldendorf
220 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: MyDac Table mit Open und FetchAll

  Alt Gestern, 09:25
Es hat etwas mit der Menge der daten zu tun. Wenn ich eine Tabelle mit 6.000 Datensätzen nehme dann kommt keine Fehlermeldung bei Close.

Eine Tabelle mit 500.000 Datensätzen macht Probleme.

Der Testaufbau ist simpel. Ich klicke "Open" dann werden sofort Daten im DBGrid angezeigt.
Wenn ich dann "Close" klicke kommt die Fehlermeldung. Auch wenn ich 10 Sekunden warte.

Delphi-Quellcode:
unit Unit3;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Data.DB, Vcl.Grids, Vcl.DBGrids, MemDS,
  DBAccess, MyAccess, Vcl.StdCtrls;

type
  TForm3 = class(TForm)
    btnOpen: TButton;
    MyConnection1: TMyConnection;
    MyTable1: TMyTable;
    DataSource1: TDataSource;
    DBGrid1: TDBGrid;
    btnClose: TButton;
    cbFetchAll: TCheckBox;
    cobTableNames: TComboBox;
    procedure btnOpenClick(Sender: TObject);
    procedure btnCloseClick(Sender: TObject);
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;

var
  Form3: TForm3;

implementation

{$R *.dfm}

procedure TForm3.btnOpenClick(Sender: TObject);
begin
  MyTable1.TableName := cobTableNames.Text;
  //--
  if NOT cbFetchAll.Checked then
    MyTable1.FetchAll := false;
  //--
  MyTable1.Open;
end;

procedure TForm3.btnCloseClick(Sender: TObject);
begin
  MyTable1.Close;
end;

end.
  Mit Zitat antworten Zitat
Edelfix

Registriert seit: 6. Feb 2015
Ort: Stadtoldendorf
220 Beiträge
 
Delphi 10.4 Sydney
 
#5

AW: MyDac Table mit Open und FetchAll

  Alt Gestern, 16:02
Habe noch keine Antwort von Devart bekommen. Sind erst zwei Tage rum.

Um die Zeit zu nutzen habe ich jetzt UniDac Trial ausprobiert. Das funktioniert ohne Fehlermeldung.

Dafür hat die UniDac Komponente keine "FetchAll" Property sondern "SmartFetch". Erst ein mal vielversprechend.

Nur ist es so das die Daten zwar schnell sichtbar sind aber wenn ich ein "SetRange" oder Filter setze mir die Anwendung einfriert.

Ich komme nicht dahinter wie Devart sich die Verarbeitung von vielen Datensätzen mit einer Table Komponente gedacht hat.
Mir ist auch aufgefallen das es schlagartig langsamer wird ab etwa 400.000 Datensätzen.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.313 Beiträge
 
Delphi 12 Athens
 
#6

AW: MyDac Table mit Open und FetchAll

  Alt Gestern, 17:39
Die 6000 Datensätze passen vermutlich noch in die Range rein und werden sofort geladen.
Konnte man nicht irgendwo einstellen, wie groß der Bereich ist, welcher beim Fetching geladen werden soll?
Ein Therapeut entspricht 1024 Gigapeut.
  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 01:14 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