AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi MySQL direct und stream und RTF
Thema durchsuchen
Ansicht
Themen-Optionen

MySQL direct und stream und RTF

Offene Frage von "StTüff"
Ein Thema von StTüff · begonnen am 4. Dez 2007
Antwort Antwort
StTüff

Registriert seit: 3. Dez 2002
132 Beiträge
 
Delphi 2006 Enterprise
 
#1

MySQL direct und stream und RTF

  Alt 4. Dez 2007, 12:20
Datenbank: MySQL • Version: 4.1.14-nt • Zugriff über: MYSQL direct
Hallo!

Ich greife auf eine MySQL-Datenbank über "MySQL direct" zu. Das hat bisher recht gut funktioniert. Nun soll aber ein RTF-Text in der Datenbank gespeichert werden. Das habe ich auf direktem Weg nicht hinbekommen:
Delphi-Quellcode:
function GetRTFFromRichEdit(): String;
var StrS : TStringStream;
begin
  StrS := TStringStream.Create('');
  try
    MainForm.Richedit1.Lines.SaveToStream(StrS);
    Result := StrS.DataString;
  finally
    StrS.Free;
  end;
end;
Delphi-Quellcode:
procedure TMainForm.ToolButtonRTFSave(Sender: TObject);
var q: string;
    ex: boolean;
begin
  Memo1.Text := QuotedStr(GetRTFFromRichEdit);
  if assigned(FResult) then begin
    if FMysql.Status<>MYSQL_STATUS_READY then
      ShowMessage('Ein Ergebnis wurde unvollständig gelesen!');
      FreeAndNil(FResult);
  end;
  FResult := FMysql.query(
    'INSERT INTO req_items (text) VALUES ('''+GetRTFFromRichEdit+''')', true, ex);
  if assigned(FResult) then
    ShowMessage('Query: OK - Ergebnis gespeichert')
  else
    if ex then
      ShowMessage('Query: OK - ausgeführt')
    else
      ShowMessage('Query fehlgeschlagen: '+FMysql.LastError);
  FreeAndNil(FResult);
end;
(Es handelt sich um ein Q&D-Beispiel, also bitte nicht auf jeder unnötigen Variable rummhacken - Danke!)

Hier werden diverse (notwendige) Zeichen nicht korrekt gespeichert.

Daraufhin habe ich an vielen Stellen im Forum gelesen, dass man RTF in einer Datenbank nur über einen Stream in ein Binärdatenfeld (z.B. blob) speichern kann. Ich habe aber keine Ahnung wie das (und ob das überhaupt) mit MySQL direct geht.

Deshalb folgende Fragen an Euch:
- Können mit MySQL direct streams verarbeitet werden?
Wenn ja:
- Wie geht das? Hat mir jemand ein Beispiel?
Wenn nein:
- Gibt es eine andere Möglichkeit den RTF-Text mit MySQL direct in der Datenbank zu speichern (und wieder auszulesen), oder muss ich auf eine andere Zugriffsmethode ausweichen?

Gruß und schon mal besten Dank an alle!

StTüff
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:26 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