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 2 von 36     12 3412     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)
 
bender251
 
#11
  Alt 14. Okt 2003, 12:35
Schande über mich........

Natürlich.......
Ich Idiot hatte nicht Insert sondern Update geschrieben. Klar, dass dann keine Datensätze hinzugefügt werden können. Klappt jetzt prima!


Vielen Dank für dein Tutorial. Wenn du mir noch eine grundlegende Frage beantworten könntest, damit ich sicher gehe, dass ich net alles um sonst umschreibe:

Also mit MySQL können mehrere User gleichzeitig auf die Datenbank zugreifen und auch Schreibzugriffe ausführen? Also können in einem Netzwerk 2 oder mehr Pcs ein Feld gleichzeitig beispielsweise um 1 erhöhen mit dem Befehl

'Update kandidaten SET nummer = nummer + 1 WHERE name = xyz' Und dann werden auch beide Schreibzugriffe verarbeitet?

Danke für die schnelle Hilfe hier im Forum

dickes Lob an alle


Gruß bender251
  Mit Zitat antworten Zitat
Chewie

 
Turbo Delphi für Win32
 
#12
  Alt 14. Okt 2003, 13:24
Gleichzeitige Zugriffe sind immer ein Problem. AFAIK wird das Problem umgangen, indem ein Schreibchutz um die Felder gelegt wird, die gerade beschrieben werden, sodass andere Prozesse (bei MySQL die Bezeichnung für einen einngelogten Benutzer) sich nicht in die Quere kommen können. Wie das aber im einzelnen funktioniert und welche Probleme dabei auftreten, kann ich dir aber nicht sagen. Du könntest dazu mal das MySQL-Manual zu Rate ziehen.

In der Regel sollte aber die Situation, dass zwei Benutzer wirklich gleichzeitig auf ein und das selbe Feld schreibend zugreifen, sehr selten auftauchen, sodass du dir in den meisten Fällen keine Gedanken darum machen musst.
Martin Leim
  Mit Zitat antworten Zitat
Supremacy
 
#13
  Alt 17. Okt 2003, 13:28
Super Klasse Tutorial !!!
Dickes fettes Lob von mir, sowas habe ich schon immer gesucht.

Klappt alles perfekt.

Das hat mir echt super weitergeholfen und man kann auf die lästigen VCL's verzichten


EDIT: mmmh ich habe verschiedene versionen von der DLL datei, kann mir jemand sagen welche die richtige ist ?
  Mit Zitat antworten Zitat
sentinal
 
#14
  Alt 22. Okt 2003, 10:51
Hallo,

unter php gibt es noch die schöne Funktion mysql_fetch_assoc.
Dadurch kann man direkt per Feldname darauf zugreifen.
SELECT id, name, email FROM benutzer WHERE reg_date > UNIX_TIMESTAMP()-3600 LIMIT 1
Code:
$row = mysql_fetch_assoc($result);
echo $row['id'].": ".$row['name'].", ".$row['email'];
Kann man sowas auch mit dieser Methode das in Delphi verwirklichen?
  Mit Zitat antworten Zitat
Benutzerbild von Wormid
Wormid

 
Delphi XE2 Professional
 
#15
  Alt 22. Okt 2003, 11:10
Nein, soweit ich weiss, geht das so ohne weiteres nicht.

Die Funktion "mysql_fetch_row" gibt nur ein Array von [0] bis [AnzahlFelder -1] aus.

Sowas wie "mysql_fetch_array" müsste man sich dann vielleicht selber basteln.
(Mit Hilfe von "mysql_num_fields", "mysql_fetch_fields" etc...)


Gruß

Wormid
  Mit Zitat antworten Zitat
Chewie

 
Turbo Delphi für Win32
 
#16
  Alt 22. Okt 2003, 11:13
Da es in PHP ja eine native Unterstützung für Hashes gibt, wurde diese Möglichkeit für die PHP-API von mySQL wohl eingebaut. Da es diese aber nicht in C, für das die API entwickelt ist, (und natürlich auch nicht in Pascal) gibt, musst du wohl mit den Indizes vorlieb nehmen.
Martin Leim
  Mit Zitat antworten Zitat
sentinal
 
#17
  Alt 22. Okt 2003, 11:24
hm, ... schade...
naja werde dann mal mein glück verssuchen
danke trotzdem
  Mit Zitat antworten Zitat
bender251
 
#18
  Alt 29. Okt 2003, 08:52
Hallo


hab ne Frage zu dem Tutorial: Also ich habe jetzt versucht mein Programm über Netzwerk laufen zu lassen. Ich habe also den MySQl-Zugriff auf meinen MySQL-Server, der unter Apache läuft mit dem Tutorial hier realisiert. Solange das Programm auf dem gleichen PC läuft, also unter localhost auf den MySQL-Server zugreifen kann klappt alles prima. Aber sobald ich das Programm auf meinem Laptop laufen lasse und über nEtzwerk unter Angabe der IP versuche auf die lokale MySQL-Datenbank zuzugreifen kriege ich ne Fehlermeldung, bzw er stürzt ab.

Ich gebe ihm dann als host 192.168.1.5 an, auch mit '192.168.1.5' klappt es nicht. Auf dem PC mit der IP 192.168.1.5 läuft der MySQL-Server.

Woran könnte das liegen? Hat da jemand eine Idee?

Vielen Dank im Voraus
Gruß bender251
  Mit Zitat antworten Zitat
bender251
 
#19
  Alt 29. Okt 2003, 10:34
Problem gelöst!

Mein Problem hat sich erledigt. Hatte vergessen auf den Client-PC die libmysql.dll mitzukopieren . Klappt jetzt.

Gruß bender251
  Mit Zitat antworten Zitat
Benutzerbild von shareholder
shareholder

 
Delphi 7 Enterprise
 
#20
  Alt 2. Nov 2003, 00:02
hi !

ich habe alles gemacht wie es im ersten beitrag steht, doch leider kommt folgende fehlermeldung:

Benachrichtigung über Debugger-Exception

Im Projekt Projekt2.exe ist eine Excetion der Klasse EAccessViolation aufgetreten. Meldung: 'Zugriffsverletzung bei Adresse 00000000. Lesen von Adresse 00000000'. Prozess wurde angehalten. Mit einzelne Anweisung oder Start fortsetzen.

Was soll ich tun ? ich danke euch lieben schonmal ! SPITZEN TUTORIAL !
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 36     12 3412     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 05:47 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