AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi MySql Direct - Zeigt nur manchmal etwas an
Thema durchsuchen
Ansicht
Themen-Optionen

MySql Direct - Zeigt nur manchmal etwas an

Ein Thema von citybreaker · begonnen am 25. Jun 2008 · letzter Beitrag vom 27. Jun 2008
Antwort Antwort
citybreaker
(Gast)

n/a Beiträge
 
#1

MySql Direct - Zeigt nur manchmal etwas an

  Alt 25. Jun 2008, 16:38
Datenbank: MySql • Zugriff über: MySql Direct
Hallo!

Um ein paar Daten aus meiner Datenbank auszulesen benutze ich folgenden Code.
Delphi-Quellcode:
procedure Auflisten;
var ex: boolean;
    q: string;
    i: Integer;
begin
  if fMySql.Connect then begin
    if assigned(FResult) then begin
      if FMysql.Status<>MYSQL_STATUS_READY then
        FreeAndNil(FResult);
    end;

    q := 'SELECT * FROM test';
    fResult := fMySql.query(q,true,ex);

    MainFrm.lview.Clear;
    i := -1;
    fResult.First;
    while not fResult.Eof do begin
      i := i+1;
      MainFrm.LView.Items.Add;
      MainFrm.LView.Items[i].Caption := fResult.FieldValueByName('id');
      MainFrm.LView.Items[i].SubItems.Add(fResult.FieldValueByName('name'));
      MainFrm.LView.Items[i].SubItems.Add(fResult.FieldValueByName('mail'));
      fResult.Next;
    end;
  end;
end;

// Beim Start verbinden und auflisten
procedure TMainFrm.FormCreate(Sender: TObject);
begin
  ConnectMySql;
  Auflisten;
end;

// ListView aktualisieren
procedure TMainFrm.Button1Click(Sender: TObject);
begin
  Auflisten;
end;
Wenn ich nun das ganze starte, werden die Daten aufgelistet, nach dem ich aber Button 1 zum aktualisieren
gedrückt habe passiert gar nichts. Nicht einmal wenn ich einen neuen Datensatz eingefügt habe.
Lasse ich Auflisten in der OnCreate weg, passiert auch nichts nach dem Button drücken.

Hat vielleicht jemand ne Idee woran das liegen könnte?
  Mit Zitat antworten Zitat
soulies

Registriert seit: 9. Dez 2005
234 Beiträge
 
#2

Re: MySql Direct - Zeigt nur manchmal etwas an

  Alt 26. Jun 2008, 09:03
Zitat:
while not fResult.Eof do begin
i := i+1;
MainFrm.LView.Items.Add;
MainFrm.LView.Items[i].Caption := fResult.FieldValueByName('id');
MainFrm.LView.Items[i].SubItems.Add(fResult.FieldValueByName('name'));
MainFrm.LView.Items[i].SubItems.Add(fResult.FieldValueByName('mail'));
fResult.Next;
end;
versuch mal hier hinter noch ein 'freeandnil(fresult)'

Zitat:
q := 'SELECT * FROM test';
greifst du damit auf die MySQL eigene Datenbank 'test' zu ?

edit: Code umgestellt ...
Delphi-Quellcode:
procedure Auflisten;
var ex: boolean;
    q: string;
    i, records: Integer;
begin
  if fMySql.Connect then
  begin
    
    if assigned(FResult) then
    begin
      if FMysql.Status<>MYSQL_STATUS_READY then
        FreeAndNil(FResult);
    end;

    q := 'SELECT * FROM test';
    fResult := fMySql.query(q,true,ex);
    records := fResult.RowsCount;

    MainFrm.lview.Clear;
    
    for i:=0 to records-1 do
    begin
      MainFrm.LView.Items.Add;
      MainFrm.LView.Items[i].Caption := fResult.FieldValueByName('id');
      MainFrm.LView.Items[i].SubItems.Add(fResult.FieldValueByName('name'));
      MainFrm.LView.Items[i].SubItems.Add(fResult.FieldValueByName('mail'));
      fResult.Next;
    end;
    FreeAndNil(fResult);
  end;
end;
cya
  Mit Zitat antworten Zitat
citybreaker
(Gast)

n/a Beiträge
 
#3

Re: MySql Direct - Zeigt nur manchmal etwas an

  Alt 26. Jun 2008, 18:31
Danke für den Tipp, funktionieren tut es leider trotzdem noch nicht.
Ich habe das Gefühl, dass das ganze mit der ListView zusammenhängt. Wenn
ich einen der Werte in einer ShowMessage anzeigen lassen steht dort etwas
drinne, die ListView hingegen bleibt leer.
  Mit Zitat antworten Zitat
soulies

Registriert seit: 9. Dez 2005
234 Beiträge
 
#4

Re: MySql Direct - Zeigt nur manchmal etwas an

  Alt 27. Jun 2008, 08:02
was passiert wenn du statt
Zitat:
MainFrm.LView.Items[i].Caption := fResult.FieldValueByName('id');
MainFrm.LView.Items[i].SubItems.Add(fResult.FieldValueByName('name'));
MainFrm.LView.Items[i].SubItems.Add(fResult.FieldValueByName('mail'));
verwendest
Delphi-Quellcode:
MainFrm.LView.Items[i].Caption := fResult.FieldValue(0);
      MainFrm.LView.Items[i].SubItems.Add(fResult.FieldValue(1));
      MainFrm.LView.Items[i].SubItems.Add(fResult.FieldValue(2));
vllt. stimmt etwas mit deinen feldbezeichnungen nicht


cya
  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 16:41 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