1: 2: 3: 4: 5: 6: 7: 8: 9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20: 21: 22: 23: 24: 25: 26: 27: 28: 29: 30: 31: 32: 33: 34: 35: 36: 37: 38: 39: 40: 41: 42: 43: 44: 45: 46: 47: 48: 49: 50: 51: 52: 53: 54: 55: 56: 57: 58: 59: 60: 61: 62: 63: 64: 65: 66: 67: 68: 69: 70: 71: 72: 73: 74: 75: 76: 77: 78: 79: 80: 81: 82: 83: 84: 85: 86: 87: 88:
| unit Unit1;
interface
uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, ExtCtrls, StdCtrls, mySQL, ExeImageAvail;
type TForm1 = class(TForm) Log: TMemo; BtnQuery: TButton; edHost: TLabeledEdit; edUser: TLabeledEdit; edPass: TLabeledEdit; edDB: TLabeledEdit; edQuery: TLabeledEdit; procedure BtnQueryClick(Sender: TObject); procedure FormCreate(Sender: TObject); private public end;
var Form1: TForm1;
implementation
{$R *.dfm}
procedure TForm1.FormCreate(Sender: TObject); const MODULE_NAME = 'libmysql.dll'; begin BtnQuery.Enabled := IsExeImageAvailable(MODULE_NAME); if NOT BtnQuery.Enabled then ShowMessage(MODULE_NAME+' ist NICHT verfügbar!'); end;
procedure TForm1.BtnQueryClick(Sender: TObject); var DBConnection: PmySQL; query_result: PmySQL_Res; query_row: PmySQL_row; i,j: Integer; Line: String; begin DBConnection := mySQL_init(NIL); if Assigned(DBConnection) then try if Assigned(mySQL_real_connect(DBConnection, PChar(edHost.Text), PChar(edUser.Text), PChar(edPass.Text), PChar(edDB.Text), MYSQL_PORT, NIL, 0)) then begin mySQL_real_query(DBConnection, PChar(edQuery.Text), Length(edQuery.Text)); query_result := mySQL_store_result(DBConnection); if Assigned(query_result) then begin Log.Lines.Add('Es wurden '+IntToStr(mySQL_num_rows(query_result))+' Datensätze ermittelt.'); try for i := 0 to mySQL_num_rows(query_result)-1 do begin query_row := mySQL_fetch_row(query_result); Line := ''; for j := 0 to mysql_num_fields(query_result)-1 do Line := Line +query_row[j]+','; Log.Lines.Add(Line); end; except Log.Lines.Add('Fehler beim Lesen der Abfrageergebnisse: '+Exception(ExceptObject).Message); end; mySQL_free_result(query_result); Log.Lines.Add('Abfrage erfolgreich beendet.'); end else Log.Lines.Add('Es konnten keine Datensätze zurückgegeben werden. Ursache: '+mySQL_error(DBConnection)); end else Log.Lines.Add('Die Verbindung konnte nicht hergestellt werden. Ursache: '+mySQL_error(DBConnection)); finally mySQL_close(DBConnection); end else Log.Lines.Add('Kann keinen Descriptor erzeugen!?'); end;
end. |