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 7 von 36   « Erste     567 8917     Letzte »    
Chewie
Registriert seit: 10. Jun 2002
Zugriff auf MySQL mit der MySQL-C-API

Fast jeder, der schon mit PHP gearbeitet hat, kennt wohl den Datenbankserver MySQl, und die meisten von euch werden wohl auch schon von PHP aus damit gearbeitet haben.
Während das mit PHP sehr einfach und unkompliziert ist, erscheint es mit Delphi am Anfang recht kompliziert. Gerade wenn man noch keine Datenbankerfahrungen mit Delphi verbuchen kann, erscheint die Benutzung der Zeos-Komponenten oder auch der ODBC-Schnittstelle aufwändig und kompliziert. Ganz zu schweigen von der Tatsache, dass Komponenten, die von Zeos benötigt werden, bei den Standard- und Personal-Versionen von Delphi nicht dabei sind.
Was liegt also näher, als auf diese Komponenten zu verzichten und eine Alternative zu suchen? Besonders, wenn man bereits mit PHP und MySQL gearbeitet hat, dürfte man sehr gut mit der hier vorgestellten Methode zurechtkommen.

Das Tutorial handelt davon, wie man die C-API von MySQL in Delphi einsetzt. Ja, ihr habt richtig gelesen, C-API, so heißt es auf der MySQL-Website. Nichtsdestotrotz kann man diese API (= Application Programming Interface) natürlich auch mit Delphi verwenden.
Anmerkung: SQL-Kenntnisse werden hier nicht vermittelt. Die sind Voraussetzung zum Begreifen dieses Tutorials.
Dafür notwendig sind in erster Linie einmal die Pascal-Übersetzungen der C-Header für die MySQL-Bibliothek (und natürlich die Bibliothek selbst). Die Header findet man unter http://www.audio-data.de/mysql.html, die Bibliothek libmysql.dll ist bei dem MySQL-Server dabei.
Die Pascal-Unit mysql.pas importiert die Funktionen von libmysql.dll und stellt sie Programmmierern zur Verfügung. Um auf die DLL zugreifen zu können, muss sie entweder im Programmverzeichnis liegen oder aber im Verzeichnis Windows, Windows\System oder Windows\System32.

Nachdem das getan ist, können wir die DLL verwenden. Dazu muss die Unit mysql.pas in unser Projektverzeichnis gelegt werden und per uses-Klausel eingebunden werden. Unsere Unit sieht also so aus:

Code:
unit MysqlTest;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, [b]mySQL[/b];
 
{ ... }

Bevor wir anfangen, mit dem SQL-Server zu arbeiten, kommen einige kleine Anmerkungen.
Eine Übersicht und Dokumentation der Funktion ist auf http://www.mysql.com/documentation/m...ction_overview verfügbar.
Von diesen werden in diesem Tutorial aber nur folgende verwendet:

mysql_close()
mysql_error()
mysql_fetch_row()
mysql_free_result()
mysql_init()
mysql_real_connect()
mysql_real_query()
mysql_store_result()


Die Verwendung der übrigen Funktionen sollte aber kaum Mühe bereiten, schon gar nicht, wenn man sie aus PHP kennt, da, wie man an der Auflistung sehen kann, die C-API und die PHP-API recht ähnlich sind.

Neben den Funktionen werden noch folgende Datentypen, die in mysql.pas definiert sind, benutzt:

PMySQL
PMySQL_Res
PMySQL_Rows



So, es kann nun losgehen.

Im nachfolgenden Beispiel werden wir uns zu einem MySQL-Server verbinden und ihn nach dem aktuellen Datum fragen.
Die einzelnen Schritte werden zunächst erläutert, bevor anschließend ein kurzes Code-Beispiel erklärt wird.

Bevor wir überhaupt eine Verbindung herstellen können, müssen wir unseren Verbindungsdeskriptor initialisieren. Dieser ist vom Typ PMySQL.

Ist dies getan, können wir die Verbindung herstellen.Dafür wird mysql_real_connect() benutzt.

mysql_real_connect() ist folgendermaßen augebaut:
mysql_real_connect: function(_mysql: PMYSQL; const host, user, passwd, db: pChar; port: longword; const unix_socket: pChar; clientflag: longword): PMYSQL; stdcall; Die Erklärung der einzelnen Parameter findet sich auf http://www.mysql.com/documentation/m...l_real_connect.

Als Rückgabe erhalten wir erneut unseren Verbindungsdeskriptor, der jetzt (hoffentlich) eine aktive Verbindung beschreibt.
Dies ist der Fall, wenn er ungleich nil ist.

Mit den eigentlichen Transaktionen beschäftigen wir uns im nächsten Kapitel, deshalb wird jetzt lediglich die Verbindung getrennt.
Das geschieht mittels mysql_close().


Das Beispiel:

Delphi-Quellcode:
var
  _myCon: PMySQL; //unseren Verbindungsdeskriptor
  host, user, pass, db: PChar; //die Anmeldedaten
begin
  //wir werden uns als Root-Benutzer in localhost einloggen, ohne eine
  //bestimmte Datenbank auszuwählen
  host := 'localhost';
  user := 'root';
  pass := nil;
  db := nil;
  
  //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');
  
  //zum Schluss wird die Verbindung wieder geschlossen
  mysql_close(_myCon);
end;

Im nächsten Teil werden wir ein paar einfache SELECT, INSERT, UPDATE und DELETE-Transmissionen durchführen.

[edit=Matze]Link korrigiert. MfG, Matze[/edit]
Egal wie dumm man selbst ist, es gibt immer andere, die noch dümmer sind

Geändert von Matze (24. Jul 2010 um 15:25 Uhr)
 
Gigant02

 
Delphi 7 Professional
 
#61
  Alt 3. Nov 2004, 13:58
also bei mir geht alles soweit

außer, wie bekomme ich die daten wieder aus der Datenbank raus ???

und in einen String rein

nehmen wir mal ich habe eine abfrage
SELECT Entry FROM Buch
WHERE entry = 'bla'

und will das ergebnis in einen strig haben wenn es nur ein feld ist

oder halt in ein array wenn es eine ganze liste ist

wie mache ich sowas ???

lg, Ciam
  Mit Zitat antworten Zitat
Chewie

 
Turbo Delphi für Win32
 
#62
  Alt 3. Nov 2004, 14:44
Steht hier drin.
Martin Leim
  Mit Zitat antworten Zitat
Takeshi
 
#63
  Alt 7. Nov 2004, 16:24
Hi

Vielen Dank für das Tut! Ich hatte die MySQL Driect Units mal in eine DLL compiliert, weil die Units unter Delphi 4 in der Schule nicht liefen, aber direkt mit der libmySQL.dll ist das natürlich viel sauberer und schöner

Allerdings hab ich ein Problem, zumindest ne Frage. Ich führe ein Query aus und möchte dann die Namen/Überschriften der Felder auslesen. Habe das so versucht:
Delphi-Quellcode:
[...]
_myFields := mysql_fetch_fields(_myRes);
for i:= 0 to mysql_num_fields(_myRes)-1 do
  ShowMessage('fieldname '+IntToStr(i)+#13+_myFields[i].name);
[...]
Das funktioniert so nicht - OK, ist vereinfacht und Deklarationen weggelassen, aber daran liegts nicht, denn so zB. funktionert es:
Delphi-Quellcode:
[...]
for i:= 0 to mysql_num_fields(_myRes)-1 do begin
  _myField := mysql_fetch_field_direct(_myRes,i);
  ShowMessage('fieldname '+IntToStr(i)+#13+_myField.name);
  end;
[...]
Mache ich etwas falsch ?

Danke jedenfalls schonmal und Grüße, Christoph
Christoph Friedrich
  Mit Zitat antworten Zitat
Chewie

 
Turbo Delphi für Win32
 
#64
  Alt 7. Nov 2004, 16:42
Hm, ich kann darin keinen Fehler entdecken. Geh vielleicht mal im Einzelschrittmodus durch und betrachte, wie sich der Inhalt des Field-Arraysy entwickelt.
Martin Leim
  Mit Zitat antworten Zitat
Takeshi
 
#65
  Alt 7. Nov 2004, 16:52
Einzelschrittmodus
Nun, durch das ShowMessage bleibt das Programm ja bei jedem Schleifendurchgang stehen. Beim Ersten Durchgang wird das noch richtig ausgegeben. ('fieldname 0 id'). Beim zweiten Durchgang erscheint ein leerer Name ('fieldname 1 ') Und beim dritten Durchlauf erscheint eine Fehlermeldung 'Access violation...'
Christoph Friedrich
  Mit Zitat antworten Zitat
Chewie

 
Turbo Delphi für Win32
 
#66
  Alt 7. Nov 2004, 17:58
Hm, das könnte ich mir eigentlich nur erklären, wenn du mysql_fetch_fields nicht außerhalb, sondern innerhalb der Schleife aufgerufen hättest. Aber hast du ja nicht
Martin Leim
  Mit Zitat antworten Zitat
Gigant02

 
Delphi 7 Professional
 
#67
  Alt 11. Dez 2004, 13:55
hallo

also nun hab ich zeit gefunden und wieder mit mit der sql anbindung rumversucht
also es geht alles super blos ich bekomm die daten nicht aus der Datenbank raus !!!!

Delphi-Quellcode:
procedure TForm1.Button2Click(Sender: TObject);

  type
    TPostEntry = record
    laufendenummer : Integer;
    firma : String[255];
    ansprechpartner : String[255];
    c_telefon : String;
  end;
  TPostEntries = Array of TPostEntry;

var cNeuPfad : string;
    cFile : string;
    c_inhalt : string;
    n_FileHandle : integer;
    Posts : TPostEntries;
    idAuthor : String; //zum Zwischenspeichern der Verfasser-ID
    query : PChar;
    _myCon : PMySQL;
    _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;
    host : PChar;
    user : PChar;
    pass : PChar;
    db : PChar;
    _myCont : PMySQL;

begin
//---(verbindung hergestellen)

   host := 'localhost';
   user := 'root';
   pass := '';
   db := 'bewerbung';

   _myCont := mysql_init(nil);

   if mysql_real_connect(_myCont, host, user, pass, db, 3306, nil, 0)
   = nil then
    begin
// ShowMessage('verbung fehlgerschlagen');
    end;

// Showmessage('verbunden');


  query := 'SELECT * FROM adressen';
  mysql_real_query(_myCont, query, Length(query));

  _myRes := mysql_store_result(_myCont); //alle Datensätze vom Server anfordern
  if _myRes = nil then
  begin
    ShowMessage('Es konnten keine Datensätze zurückgebenen werden. Ursache: ' + mysql_error(_myCont));
    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].laufendenummer := inttostr(_myRow[0]); //ID ist erstes Feld im Datensatz
    Posts[i].firma := _myRow[1]; //Zeitpunkt ist zweites Feld
    Posts[i].telefonnummer := _myRow[2]; //Text ist drittest Feld
    query := PChar('SELECT name FROM users WHERE id=' + idAuthor);
    _mySubRes := mysql_store_result(_myCont);
    _mySubRow := mysql_fetch_row(_mySubRes);

    mysql_free_result(_mySubRes); //Ergebnissatz löschen
    ShowMessage(Posts[i].firma);
  end;

  mysql_free_result(_myRes); //Ergebnissätze löschen

end;
wie bekomme ich die daten von denn Datenbank Feld firma und telefonnummer in einen Tring ??? ich will das dan in einer Textdatei speichern das soll nicht das problem sein also mit der text datei aber ich bekomme die daten einfach nicht in einen String wie mache ich das an besten ???

lg, Ciam
  Mit Zitat antworten Zitat
Benutzerbild von emsländer
emsländer

 
RAD-Studio 2009 Ent
 
#68
  Alt 8. Jan 2005, 13:56
Hallo zusammen,


prodecure schleim
begin
showmessage('Ich finde dieses Tutorial erste Klasse! Dank an allen, die hier mitarbeiten.');
end;

Habe heute viel geschafft. - Dank der Kollegen hier. Ich werde bei Gelegenheit (sobald ich etwas Luft habe) auch noch was zupacken.

Gruss und Danke

EL
  Mit Zitat antworten Zitat
fungunner2

 
Delphi 6 Personal
 
#69
  Alt 14. Jan 2005, 02:51
Hallo zusammen
Klasse TUT hier !
Möchte aber mal anfragen, obs da ein Limit gibt,
wieviel Text ich in eine Zelle schicken kann, welche ich als longtext deklariert habe ?


mfg
Hans
  Mit Zitat antworten Zitat
Chewie

 
Turbo Delphi für Win32
 
#70
  Alt 14. Jan 2005, 09:22
Die maximalen Größen für Longtext und die anderen Spaltentypen stehen in der MySQL-Doku.
Martin Leim
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 7 von 36   « Erste     567 8917     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 07:55 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