AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi BLOB-Felder vergessen ihren Inhalt nicht
Thema durchsuchen
Ansicht
Themen-Optionen

BLOB-Felder vergessen ihren Inhalt nicht

Ein Thema von Smodibo · begonnen am 7. Sep 2005 · letzter Beitrag vom 7. Sep 2005
Antwort Antwort
Smodibo
(Gast)

n/a Beiträge
 
#1

BLOB-Felder vergessen ihren Inhalt nicht

  Alt 7. Sep 2005, 13:05
Datenbank: Oracle, SQL-Server, Paradox • Zugriff über: BDE
Hallo,

ich habe hier in einer Oracle-Datenbank via BDE ein leeres Blob-Feld mit einem Wert gesetzt, dann gespeichert. Danach habe ich versucht, den Wert zu löschen, Posten der Query geht noch, aber nach ApplyUpdates hat das Blob-Feld den Wert vor dem Löschen wieder. Scheinbar wird der leere String nicht auf den Blob-Stream abgebildet.

Kommt dieses Verhalten von der BDE oder Oracle? Hat jemand Erfahrungen? Ich setze momentan einfach ein Leerzeichen ein, wenn das Blob geleert werden soll.

freundliche Grüße
  Mit Zitat antworten Zitat
dfried

Registriert seit: 16. Aug 2005
486 Beiträge
 
#2

Re: BLOB-Felder vergessen ihren Inhalt nicht

  Alt 7. Sep 2005, 13:14
Ein bisschen Sourcecode wäre vielleicht hilfreich bei der Problemlösung...
  Mit Zitat antworten Zitat
Smodibo
(Gast)

n/a Beiträge
 
#3

Re: BLOB-Felder vergessen ihren Inhalt nicht

  Alt 7. Sep 2005, 13:25
1. Zum Anfang habe ich ein leeres BLOB-Feld.
2. Ich trage dann einen Wert in das Feld ein und speicher diesen ab (Siehe Quellcode).
3. Dann lösche ich den kompletten Wert aus dem Feld.
4. Dann speichere ich wieder und der Wert ist nach dem ApplyUpdates der Query wieder da.

Die Datenmenge wird wie folgt gespeichert:

Delphi-Quellcode:
with Query do
begin
  try
    if not Database.InTransaction then
      Database.StartTransaction;
    ApplyUpdates;
    Database.Commit;
  except
    on E: Exception do
    begin
      Database.Rollback;
      MessageDlg('Speichern nicht erfolgreich' + #13#10 + E.Message, mtError,[mbOk], 0);
    end;
  end;
  CommitUpdates;
end;
  Mit Zitat antworten Zitat
dfried

Registriert seit: 16. Aug 2005
486 Beiträge
 
#4

Re: BLOB-Felder vergessen ihren Inhalt nicht

  Alt 7. Sep 2005, 13:33
Interessant wäre egentlich der Quellcode, wo du das BLOB-Feld zuweist.
Aber versuch doch mal statt dem Feld einen leerstring zuzuweisen
query.fieldByName('feldname').CLEAR zu machen oder gegebenenfalls NULL zuzuweisen.
  Mit Zitat antworten Zitat
Smodibo
(Gast)

n/a Beiträge
 
#5

Re: BLOB-Felder vergessen ihren Inhalt nicht

  Alt 7. Sep 2005, 14:01
Ich habe in einem Formular eine DBMemo-Komponente. Dahinter liegt das BLOB-Feld.
Ich trage dann in die Komponente den Wert ein.

Das passiert aber auch über einen Datenbankmanager, wie z.B. SQL-Explorer.
  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 09:13 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