![]() |
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 |
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:
|
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:
Ich habe allerdings nicht noch andere Versionen von Delphi ausführlich getestet. Mit Seattle sollte es auf jeden Fall gehen.
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; |
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 04:07 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