![]() |
Ini-Datei in DB-Feld verlegen
Hintergrund: Im Moment habe ich mehrere DLLs, die eigene INI-Dateien haben, in denen verschiedene Einstellmöglichkeiten drin stehen (für jede DLL steht da was anderes drin). Diese INI-Dateien müssen in die DB verlagert werden, damit ich von überall Zugriff drauf habe.
Meine Idee: Ich mache ein neues DB-MemoFeld in dem dann der Inhalt der bisherigen Ini-Datei drin steht. Mein Problem dabei: Um weiterhin die Funktionen aus TIniFiles wie ReadString, ReadSection, etc. verwenden zu können, hätte ich das gerne genommen, jedoch will TIniFiles einen Dateinamen beim Create, den ich ja dann nimmer hätte. Meine Fragen: Kann ich TIniFiles o.ä. auch ohne Datei verwenden? Steh ich grad aufm Schlauch oder macht das so gar keinen Sinn? Soll ich lieber eine andere Richtung gehen? |
AW: Ini-Datei in DB-Feld verlegen
Ohne es ausprobiert zu haben: TMemIniFile verwenden, ohne Dateinamen erzeugen und mit SetStrings befüllen, die dort anzugebende TStrings-Instanz kann man ja im Vorfeld aus dem BLOB laden.
[edit] Falls keine Sections benötigt werden, ginge es mit den Key/Value-Methoden von TStrings sogar noch einfacher. [/edit] |
AW: Ini-Datei in DB-Feld verlegen
Mit "ohne Dateinamen erzeugen" ist wohl "Mit Nonsens-Dateinamen (wie leeren String) erzeugen" gemeint. Denn der Konstruktor will auf jeden Fall einen :wink:
Erst wenn du
Delphi-Quellcode:
aufrufen würdest, käme es zu Problemen.
myMemFile.UpdateFile()
PS: Ich habe mich auch ganz von der "normalen" TIniFile verabschiedet, den diese baut noch auf irgendwelche 16-Bit Windows-Funktionen auf die gerne mal fehlschlagen. Mit TMemIniFile ist mein Leben ein besseres geworden. |
AW: Ini-Datei in DB-Feld verlegen
Du könntest ja auch eine eingene Klasse schreiben, "TDBIni" oder so, die nach aussen hin genau die selben Möglichkeiten bietet, wie TIniFiles, sprich ReadString, WriteString usw. Jenachdem was du so brauchst kannst du ja auch Dinge die du nicht brauchst weglassen (RedSections oder so) wobei das in sofern schlecht ist, das man von einer Klasse mit INI im Namen so Funktionen erwarten würde (bei späterer Wiederverwendung).
Intern aber wandelt die Klasse das in DB-Abfragen usw. um, d.h. natürlich auch, dass du dafür in der DB eine passende Tabelle brauchst. |
AW: Ini-Datei in DB-Feld verlegen
Natürlich meinte ich einen Leerstring, man kann ja keine Parameter weglassen ;)
|
AW: Ini-Datei in DB-Feld verlegen
Generell würde ich ab einer bestimmten Ebene nicht mehr mit
Delphi-Quellcode:
u.ä. arbeiten, sondern mir immer eine abstrakte Klasse oder Interface bauen, die für den Zugriff auf wie auch immer geartete Informationen/Resourcen verantwortlich ist.
TIniFile
Wie das dann implementiert ist (mit
Delphi-Quellcode:
, oder ...) spielt dann keine Rolle mehr, Hauptsache die Implementierung liefert das Gewünschte.
TIniFile
|
AW: Ini-Datei in DB-Feld verlegen
Dann würde ich die Ini-Dateien aber nicht in einem (B)LOB ablegen, sondern die Struktur direkt in der DB Abbilden.
|
AW: Ini-Datei in DB-Feld verlegen
Ich habe genau so einen Fall und mache es so: (s. DeddyH)
Delphi-Quellcode:
IniFile:=TMemIniFile.Create('');
Data:=TStringList.create; Data.Text:=TableIni.FieldByName('Data').AsString; IniFile.SetStrings(Data); |
AW: Ini-Datei in DB-Feld verlegen
Zitat:
|
AW: Ini-Datei in DB-Feld verlegen
Zitat:
Beispiel:
Delphi-Quellcode:
{*******************************************************}
{ } { CodeGear Delphi Runtime Library } { } { Copyright(c) 1995-2013 Embarcadero Technologies, Inc. } { } {*******************************************************} unit System.IniFiles; [...] procedure TIniFile.WriteString(const Section, Ident, Value: string); begin if not WritePrivateProfileString(MarshaledString(Section), MarshaledString(Ident), MarshaledString(Value), MarshaledString(FFileName)) then raise EIniFileException.CreateResFmt(@SIniFileWriteError, [FileName]); end; MSDN: ![]() Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:57 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