Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Über FireDac auf MariaDB zugreifen: Nicht unterstütze MySQL-Version (https://www.delphipraxis.net/194175-ueber-firedac-auf-mariadb-zugreifen-nicht-unterstuetze-mysql-version.html)

Kostas 25. Okt 2017 09:50

Datenbank: MariaDB • Version: 10.2 • Zugriff über: Firebac

Über FireDac auf MariaDB zugreifen: Nicht unterstütze MySQL-Version
 
Hallo Zusammen,

ich habe MariaDB über das Setup mariadb-10.2.9-win32.msi installiert.

Über das Tool HeidiSQL kann ich auch einwandfrei zugreifen.

in der FDDrivers.ini habe ich den Eintrag hinzugefügt. Ich habe auch den MySQL C-Connector in 32Bit heruntergeladen und eingetragen, funktioniert auch nicht.

[MySQL]
VendorLib=C:\Program Files (x86)\MariaDB 10.2\lib\libmariadb.dll

Nun versuche ich über den FireDAC Explorer eine Verbindung herzustellen und bekomme die Fehlermeldung:
[FireDAC][Phys][MySQL]-1101, Nicht unterstütze MySQL-Version
[1002090000], Unterstützt werden Client und Server von v 3.20 bis 6.2

MariaDB 10.2 ist doch kompatibel zu MySQL 5.7

Oder muss ich MariaDB 5.6 verwenden?

Gruß Kostas

DeddyH 25. Okt 2017 10:06

AW: Über FireDac auf MariaDB zugreifen: Nicht unterstütze MySQL-Version
 
Zufällig hatte ich exakt dasselbe vor ein paar Tagen. Bob Swart hat den Tipp gegeben, die FireDAC.Phys.MySQLWrapper.pas ins Projektverzeichnis zu kopieren und zu patchen. Bei mir sieht das jetzt so aus:
Zitat:

Delphi-Quellcode:
...
procedure TMySQLLib.LoadEntries;
begin
  @mysql_get_client_info := GetProc(smysql_get_client_info);
  FVersion := FDVerStr2Int(TFDEncoder.Deco(mysql_get_client_info(), -1, ecANSI));
  // Für MariaDB den Versionscheck auskommentiert
  {if (FVersion < mvMySQL032000) or (FVersion >= mvMySQL060200) then
    FDException(OwningObj, [S_FD_LPhys, S_FD_MySQLId], er_FD_MySQLBadVersion,
      [FVersion]);}

  @mysql_num_fields := GetProc(smysql_num_fields);
...


jaenicke 25. Okt 2017 10:18

AW: Über FireDac auf MariaDB zugreifen: Nicht unterstütze MySQL-Version
 
In der aktuellen Delphiversion ist das übrigens gefixt, da funktioniert es auch so.

Ich habe für die Version vorher (ich glaube Seattle) schlicht die Funktion im Speicher gepatcht, dann braucht man keine Kopie der Unit. Das sieht dann schlicht so aus:
Delphi-Quellcode:
uses
  Winapi.Windows, System.SysUtils,
  FireDAC.Stan.Consts, FireDAC.Phys.MySQLWrapper;

procedure AllowFireDACMariaDBVersions;

implementation

type
  THackMySQLLib = class(TMySQLLib);

function GetIncrement: Integer;
begin
  Result := 0;
  if CompilerVersion >= 31 then
  begin
    Result := $73;
  end else if CompilerVersion <= 27 then
  begin
    Result := $77;
  end;
end;

procedure SetMaxMySQLLib(const AValue: Integer);
var
  ConstAddr: PByte;
  OldProtect: DWORD;
  Increment: Integer;
begin
  ConstAddr := PByte(@THackMySQLLib.LoadEntries);
  Increment := GetIncrement;
  Inc(ConstAddr, Increment);
  VirtualProtect(ConstAddr, SizeOf(mvMySQL060200), PAGE_READWRITE, OldProtect);
  if mvMySQL060200 <> PInteger(ConstAddr)^ then
  begin
    raise Exception.Create('Interner Fehler: Maximale MySQL Versionsnummer konnte nicht korrigiert werden!');
  end;
  PInteger(ConstAddr)^ := AValue;
  VirtualProtect(ConstAddr, SizeOf(mvMySQL060200), OldProtect, OldProtect);
end;

procedure AllowFireDACMariaDBVersions;
begin
  SetMaxMySQLLib(2000000000);
end;
Ich habe allerdings nicht noch andere Versionen von Delphi ausführlich getestet. Mit Seattle sollte es auf jeden Fall gehen.

Kostas 25. Okt 2017 11:03

AW: Über FireDac auf MariaDB zugreifen: Nicht unterstütze MySQL-Version
 
Vielen herzlichen Dank an beide, es hat funktioniert.
Ich habe Sebastians Version umgesetzt.
Aktuell verwende ich Delphi 10.1 Berlin.

Gruß Kostas


Alle Zeitangaben in WEZ +1. Es ist jetzt 17:44 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