Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi CREATE DATABASE mit PageSize 32768 unter FireDAC (https://www.delphipraxis.net/212297-create-database-mit-pagesize-32768-unter-firedac.html)

WiPhi 21. Jan 2023 15:17

Datenbank: Firebird • Version: 4.0.2 • Zugriff über: FireDAC

CREATE DATABASE mit PageSize 32768 unter FireDAC
 
Moin zusammen,
ich habe ein kleines Problem mit dem Erstellen einer Firebird 4 Datenbank und einer PageSize Größe von 32768.

Folgenes führe ich zum Erstellen der Datenbank unter Delphi 11.2 (aktueller Patch ist drin) aus:
Delphi-Quellcode:
lFirebirdDataModule := TFireDACDataModule.Create(nil);
TFDPhysFBConnectionDefParams(lFirebirdDataModule.FDConnection.Params).Server := 'localhost';
TFDPhysFBConnectionDefParams(lFirebirdDataModule.FDConnection.Params).Port := 3050;
lFirebirdDataModule.FDConnection.Params.Database := 'Test';
lFirebirdDataModule.FDConnection.Params.UserName := 'SYSDBA';
lFirebirdDataModule.FDConnection.Params.Password := 'firebird';
TFDPhysFBConnectionDefParams(lFirebirdDataModule.FDConnection.Params).CharacterSet := TIBCharacterSet.csUTF8;
TFDPhysFBConnectionDefParams(lFirebirdDataModule.FDConnection.Params).ExtendedMetadata := True;
TFDPhysFBConnectionDefParams(lFirebirdDataModule.FDConnection.Params).OpenMode := TIBOpenMode.omOpen;

TFDPhysFBConnectionDefParams(lFirebirdDataModule.FDConnection.Params).PageSize := ps32768; // <- funktioniert nicht
//TFDPhysFBConnectionDefParams(lFirebirdDataModule.FDConnection.Params).PageSize := ps16384; // <- funktioniert

TFDPhysFBConnectionDefParams(lFirebirdDataModule.FDConnection.Params).OpenMode := TIBOpenMode.omCreate;
lFirebirdDataModule.FDConnection.Open();
lFirebirdDataModule.FDConnection.Close;
lFirebirdDataModule.Free;
Am Ende habe ich eine Datenbank mit einer Pagesize von 8192 (Default). Setze ich die PageSize auf 16384 wird die Datenbnak auch mit der korrekten Größe angelegt.

Führe ich ein
Code:
CREATE DATABASE xyz PAGE_SIZE 32768
manuell mit isql aus, bekomme ich eine Datenbank mit der gewünschten PageSize erstellt.

Hat jemand einen Tipp, was ich falsch mache oder ist das vielleicht sogar noch ein Bug in FireDAC?

Viele Grüße und eine schönes Wochenende :)

WiPhi 23. Jan 2023 10:51

AW: CREATE DATABASE mit PageSize 32768 unter FireDAC
 
Liste der Anhänge anzeigen (Anzahl: 1)
Ich habe mal ein minimalistisches Beispiel gemacht, mit dem man es unter einem Firebird 4 Embedded nachvollziehen kann (Version ist im Projekt enthalten, deswegen ist es auch etwas größer).

Einfach das Projekt öffnen, übersetzen und einmal laufen lassen. Im Win32 Verzeichnis ensteht eine FB32K.fdb.

Mit gstat -a auf diese Datei sieht man die fehlerhafte PageSize (8192).

Ändert man in der FDConnection1 die Pagesize auf 16384 wird diese korrekt angelegt.

hoika 24. Jan 2023 08:46

AW: CREATE DATABASE mit PageSize 32768 unter FireDAC
 
Hallo,
diese beiden Seiten bedeuten für mich, dass es in FireDAC noch nicht umgesetzt ist.

Definition der Page Sizes
https://docwiki.embarcadero.com/Libr...er.TIBPageSize

https://docwiki.embarcadero.com/Libr...rapper.ps32768
ps32768: TIBPageSize = TIBPageSize(Integer(ps16384) + 1);
Ich hätte ja eher erwartet:
ps32768: TIBPageSize = TIBPageSize(Integer(ps16384) + Integer(ps16384) );

WiPhi 24. Jan 2023 09:39

AW: CREATE DATABASE mit PageSize 32768 unter FireDAC
 
Liste der Anhänge anzeigen (Anzahl: 2)
Hallo, danke für deine Antwort.

Lt. https://quality.embarcadero.com/browse/RSP-36783 sollte es implementiert sein.

Ich habe die entscheidenden Stellen auch debuggt und keinen offensichtlichen Fehler erkannt. Die PageSize wird korrekt als Parameter ausgewertet und nach CreateDatabase übergeben:
Anhang 55774

Im CreateDatabase werden die Parameter in einen Firebird-Typen umgewandelt (Env.BuildPB) und dort vermute ich ein Problem mit den Datentypen:
Anhang 55775

Vielleicht ist es auch ein Problem des DLL-Aufrufs an Fisc_create_database.

Wie auch immer, ich habe über die Subscription an Embarcdero das Problem berichtet.

Viele Grüße.

WiPhi 27. Jan 2023 13:08

AW: CREATE DATABASE mit PageSize 32768 unter FireDAC
 
Das Problem ist nun offiziell bei Embarcadero im Quality-Portal hinterlegt. Wer möchte, kann gern für das Issue voten:

https://quality.embarcadero.com/browse/RSP-40455


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