AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Tutorials Delphi MySQL ohne Komponenten
Tutorial durchsuchen
Ansicht
Themen-Optionen

MySQL ohne Komponenten

Ein Tutorial von Chewie · begonnen am 14. Jul 2003 · letzter Beitrag vom 30. Mär 2020
Antwort Antwort
Seite 4 von 34   « Erste     234 5614     Letzte »    
Benutzerbild von JASH
JASH

Registriert seit: 19. Dez 2003
16 Beiträge
 
Delphi 7 Architect
 
#1

Re: MySQL ohne Komponenten

  Alt 19. Dez 2003, 10:04
Danke, guter beitrag, besser erklärt als auf so manch anderen seiten, funzt auch "fast" alles, habe nur ein problem, bei Delphi 7 kennt er TPostEntries nicht, demnach funzt auch des proggi nicht, kann mir da bitte einer weiterhelfen ?
  Mit Zitat antworten Zitat
teebee

Registriert seit: 17. Jan 2003
Ort: Köln
460 Beiträge
 
Delphi 6 Professional
 
#2

Re: MySQL ohne Komponenten

  Alt 19. Dez 2003, 11:00
TPostEntries = Array of TPostEntry; Siehe drittes Posting auf der ersten Seite des Threads. Vielleicht hast Du vergessen, diese Zeile zu pasten?

Gruß, teebee
  Mit Zitat antworten Zitat
Benutzerbild von JASH
JASH

Registriert seit: 19. Dez 2003
16 Beiträge
 
Delphi 7 Architect
 
#3

Re: MySQL ohne Komponenten

  Alt 19. Dez 2003, 12:53
oh, danke für die antwort, total vergessen

dafür hab ich nu nen anderes prob

wenn ich

Posts[i].id := InttoStr(_myRow[0]); //ID des Posts ist erstes Feld im Datensatz erhalte ich die Fehlermeldung

[Fehler] dbverb2_u.pas(92): Inkompatible Typen: 'Integer' und 'String' hab den code aber kopiert, kann also kein schreibfehler meinerseits sein, da der code aber bei einigen usern funzt, der Autor laut eigenen Info`s delphi 5 benutzt, ich aber delphi 7 dürfte dass Problem dort liegen, kann mir da jemand weiterhelfen ?
  Mit Zitat antworten Zitat
Chewie

Registriert seit: 10. Jun 2002
Ort: Deidesheim
2.886 Beiträge
 
Turbo Delphi für Win32
 
#4

Re: MySQL ohne Komponenten

  Alt 19. Dez 2003, 18:19
Die Zeile müsste so richtig sein. Mit der Delphi-Version kann das nichts zu tun haben, ab Delphi4 muss das Verhalten in diesem Fall identisch sein.
Die Typen in der von dir genannten Zeile stimmen. TPostEntry.id ist ein Integer und die Elemente in PMySQL_Row[] sind Strings. Taucht der Fehler wirklich in der Zeile auf? Das würde mich wundern. Poste doch mal die umliegenden Zeilen.
Martin Leim
Egal wie dumm man selbst ist, es gibt immer andere, die noch dümmer sind
  Mit Zitat antworten Zitat
Benutzerbild von JASH
JASH

Registriert seit: 19. Dez 2003
16 Beiträge
 
Delphi 7 Architect
 
#5

Re: MySQL ohne Komponenten

  Alt 19. Dez 2003, 19:38
Ich weiss, dass is ja des prob des ich habe, hab den code 1:1 kopiert und nichts verändert abgesehen von den verbindungsdaten.

Delphi-Quellcode:
type
  TPostEntry = record
    id: Integer;
    author: String[50];
    time: String[255];
    text: String;
  end;
  TPostEntries = Array of TPostEntry;

procedure TForm1.Button1Click(Sender: TObject);
var
  host, user, pass, db, query: PChar; //die Anmeldedaten
  Posts: TPostEntries;
  idAuthor: String; //zum Zwischenspeichern der Verfasser-ID
  _myRes: PMySQL_Res; //hier wird der gesamte Ergebnissatz gespeichert
  _mySubRes: PMySQL_Res; //benötigt, um Autor zu ermmitteln
  _myRow: PMySQL_Row; //enthält den aktuellen Datensatz
  _mySubRow: PMySQL_Row; //benötigt, um Autor zu ermmitteln
  i: Integer;
begin
  //wir werden uns als Root-Benutzer in localhost einloggen, ohne eine
  //bestimmte Datenbank auszuwählen
  host := '****';
  user := '****';
  pass := '****';
  db := '****';
 
  //jetzt wird _myCon initialisiert
  _myCon := mysql_init(nil);
  if _myCon = nil then
  begin
    ShowMessage('Nicht genug freier Speicher, um Verbindungsdeskriptor zu initialisieren');
    Exit;
  end;
 
  //anschließend wird die Verbindung hergestellt
  if mysql_real_connect(_myCon, host, user, pass, db, 3306, nil, 0) = nil then
  begin
    ShowMessage('Die Verbindung konnte nicht hergestellt werden. Ursache: ' + mysql_error(_myCon));
    Exit;
  end;

  ShowMessage('Verbindung hergestellt');

  mysql_real_query(_myCon, 'CREATE TABLE posts(id int, author int, date datetime, entry text)', Length(query));
  mysql_real_query(_myCon, 'CREATE TABLE users(id int, name varchar(50), pass varchar(50))', Length(query));

  query := 'SELECT * FROM posts ORDER BY id';
  mysql_real_query(_myCon, query, Length(query));
 
  _myRes := mysql_store_result(_myCon); //alle Datensätze vom Server anfordern
  if _myRes = nil then
  begin
    ShowMessage('Es konnten keine Datensätze zurückgebenen werden. Ursache: ' + mysql_error(_myCon));
    Exit;
  end;
 
  SetLength(Posts, mysql_num_rows(_myRes)); //Posts-Array-Größe auf Anzahl der Datensätze setzen
 
  for i := 0 to High(Posts) do
  begin
    _myRow := mysql_fetch_row(_myRes); //Datensatz abholen
    Posts[i].id := InttoStr(_myRow[0]); //ID des Posts ist erstes Feld im Datensatz
    Posts[i].time := _myRow[2]; //Zeitpunkt ist drittes Feld
    Posts[i].text := _myRow[3]; //Text ist viertes Feld
   
    idAuthor := _myRow[1];
    query := PChar('SELECT name FROM users WHERE id=' + idAuthor);
    _mySubRes := mysql_store_result(_myCon);
    _mySubRow := mysql_fetch_row(_mySubRes);
    Posts[i].author := _mySubRow[0];
   
    mysql_free_result(_mySubRes); //Ergebnissatz löschen
  end;
 
  mysql_free_result(_myRes); //Ergebnissätze löschen


end;
Schonma danke im vorraus für die kommende Antwort, wenn es da nen gescheites buch über Delphi und MySQL geben würde würd ich mir des ja reinziehen, aber es gibt höchstens MSSQL und Delphi, und mit den Verbindungstypen von Delphi bekomme ich keine Verbindung zustande was mir bei dem Beispiel hier aber sofort gelungen ist. Kann mir da vlt. jemand was empfehlen ?
  Mit Zitat antworten Zitat
Huor

Registriert seit: 1. Jan 2004
4 Beiträge
 
#6

Re: MySQL ohne Komponenten

  Alt 1. Jan 2004, 12:29
Hallo,
ich habe folgendes Problem: SQL-Statements möchte ich über ein Editfeld eingeben. Nun ist query vom Typ PChar und ich bekomme einen Typ-Konflikt (Edit.text ist ja String). Wie konvertiert man das?

Ansonsten dickes Lob für das Tutorial und Prost Neujahr.
Gruß
Huor
  Mit Zitat antworten Zitat
Benutzerbild von Duffy
Duffy

Registriert seit: 19. Mär 2003
Ort: Wuppertal
835 Beiträge
 
Delphi 3 Standard
 
#7

Re: MySQL ohne Komponenten

  Alt 1. Jan 2004, 12:36
Hallo Huor,
Query := PChar(Edit.Text); bye
Claus
Künftige Generationen wollen ihre Fehler selber machen.
Jedes Programm wird nie das können, was Du wirklich brauchst.
Das Gegenteil von gut ist gut gemeint
-----
  Mit Zitat antworten Zitat
Huor

Registriert seit: 1. Jan 2004
4 Beiträge
 
#8

Re: MySQL ohne Komponenten

  Alt 1. Jan 2004, 13:28
Danke!
Ich dachte zunächst, PCHAR wäre kein Standarddelphi-Typ und ich bräuchte irgendeinen Speziahl-Befehl
Nun läuft es.
  Mit Zitat antworten Zitat
Benutzerbild von Tyler
Tyler

Registriert seit: 19. Jun 2003
Ort: Berlin
241 Beiträge
 
#9

Re: MySQL ohne Komponenten

  Alt 9. Mär 2004, 14:08
Hallo!

Erstmal dickes Lob, gefällt mir sehr gut das Tut!

Nur eine Frage: Wenn ich das jetzt richtig verstehe, kann ich mit dieser Methode nur auslesen und in Array´s schreiben. Wie geh ich jetzt vor, um die Daten in einer Tabelle anzeigen zu lassen?

mfg
  Mit Zitat antworten Zitat
Benedikt
(Gast)

n/a Beiträge
 
#10

Re: MySQL ohne Komponenten

  Alt 9. Mär 2004, 14:32
Hi,

die Frage ist, wo du die Daten anzeigen willst.
Bei einem StringGrid kannst du z.B. so...

Delphi-Quellcode:
for i:=0 to Data.row_count-1 do
begin
   Row:=mysql_fetch_row(Data);

   for j:=0 to Data.field_count-1 do
   begin
     stringGrid1.Cells[j+1, i+1]:=Row[j];
   end;
end;
...sämtliche Daten einer Tabelle ausgeben lassen, wobei die Daten in Data stehen.
Evtl. Anpassung der Zeilen und Spalten fehlt natürlich noch.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 4 von 34   « Erste     234 5614     Letzte »    


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:25 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-2025 by Thomas Breitkreuz