AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Blobs nur bis 8KB?

Ein Thema von Phoenix · begonnen am 23. Feb 2007 · letzter Beitrag vom 26. Feb 2007
Antwort Antwort
Benutzerbild von Phoenix
Phoenix
(Moderator)

Registriert seit: 25. Jun 2002
Ort: Hausach
7.640 Beiträge
 
#1

Blobs nur bis 8KB?

  Alt 23. Feb 2007, 14:26
Datenbank: Oracle • Version: 10g • Zugriff über: ADO.NET, IDb via CoreLab
Äh.. genau:

über die Generischen ADO.NET Interfaces arbeite ich aktuell mit einer Oracle-DB, das könnte aber auch mal ggf. ein SQL-Server werden.

Nun muss ich Blobs in diese Datenbank packen. Das ganze hatte ich schonmal (anderes Projekt) direkt für den SQL Server geschrieben und wollte den nun in dieses Projekt reinziehen und dabei auf die generischen Interfaces umstellen.

Anstelle des alten SqlDbType.Image wollte ich nun DbType.Binary nehmen - nur steht da:
Zitat von Visual Studio:
A variable-length stream of binary data ranging between 1 and 8,000 bytes.
Nur sind 8,000 Bytes = 8KB etwas arg wenig. So eine typische Datei für unseren Anwendungszweck hat zwischen 0,5 und 2 MB Größe.

Was tun, sprach Zeus? Sind Blobs mit dem generischen Interface nicht zu handeln? Welcher Datentyp ist korrekt?
Sebastian Gingter
Phoenix - 不死鳥, Microsoft MVP, Rettungshundeführer
Über mich: Sebastian Gingter @ Thinktecture Mein Blog: https://gingter.org
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#2

Re: Blobs nur bis 8KB?

  Alt 23. Feb 2007, 18:48
BLOBs können bei Oracle bis zu 4 GB aufnehmen.
Normalerweise werden BOLBS ausserhalb von den Tabellen gespeichert.
In der Tabelle steht beim jeweiligen Datensatz nur ein Verweis auf die BLOB-Daten.
Bei manchen DBMS (z.B. MS SQL Server) werden die ersten x Bytes direkt in die Tabelle aufgenommen.
Wenn die BLOB-Daten also kleiner-gleich x Bytes sind, ist der Zugriff dadurch deutlich schneller.
Möglich, dass du deshalb die 8000 Bytes gelesen hast.
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von Phoenix
Phoenix
(Moderator)

Registriert seit: 25. Jun 2002
Ort: Hausach
7.640 Beiträge
 
#3

Re: Blobs nur bis 8KB?

  Alt 24. Feb 2007, 13:39
Hrm? Nochmal: Der Datentyp DbType.Binary - und das steht so auch im MSDN - ist für Binäre Daten bis zu 8000 Byte. Ich habe in solchen Datenfeldern schon Unicode-Texte drin, und die werden bei ~4000 Zeichen abgeschnitten, was in etwa 8000 Bytes entspricht.

Ich weiss sehr wohl, das Oracle BLOBS mehr als 8 KB fassen könne, genauso BLOBS in anderen Datenbanksystemen, aber wie zum Teufel kann ich diese Datenmengen auch in die DB bringen bzw. daraus auslesen wenn ich die Interfaces aus System.Data benutze, die mir nur 8000 Zeichen anbieten? Das kanns doch irgendwie nicht sein?
Sebastian Gingter
Phoenix - 不死鳥, Microsoft MVP, Rettungshundeführer
Über mich: Sebastian Gingter @ Thinktecture Mein Blog: https://gingter.org
  Mit Zitat antworten Zitat
Elvis

Registriert seit: 25. Nov 2005
Ort: München
1.909 Beiträge
 
Delphi 2010 Professional
 
#4

Re: Blobs nur bis 8KB?

  Alt 24. Feb 2007, 14:09
Zitat von Phoenix:
Hrm? Nochmal: Der Datentyp DbType.Binary - und das steht so auch im MSDN - ist für Binäre Daten bis zu 8000 Byte.
Die Hohlköpfe von MS denken bei einer DB immer zuerst an ihren eigenen kläglichen Versuch ein DBMS zu bauen.
DbType.Binary wird, wenn hinter dem IDbCommand ein OracleCommand steckt, zu einem BLob.
Robert Giesecke
I’m a great believer in “Occam’s Razor,” the principle which says:
“If you say something complicated, I’ll slit your throat.”
  Mit Zitat antworten Zitat
Benutzerbild von Phoenix
Phoenix
(Moderator)

Registriert seit: 25. Jun 2002
Ort: Hausach
7.640 Beiträge
 
#5

Re: Blobs nur bis 8KB?

  Alt 26. Feb 2007, 09:31
Seltsam...

Ich speichere die Daten via Function, damit ich im Programm keine Unterscheidung zwischen Insert und Update machen muss.

Bis 800 KB hab ichs grad probiert, das ging grad noch.

2,5 MB: Upload in die Datenbank ca. anderthalb Minuten.

5 MB: Upload in die Datenbank irgendwas über 4 Minuten.

Jetzt ein 10 MB-File... da sitzt die Anwendung jetzt seit 15 Minuten(!) dran und ich hab abgebrochen.

Das ganze hängt immer bei Command.ExecuteNonQuery. Also das ist echt mal kein Laufzeitverhaltden, was ich einem Kunden zumuten kann. Das Auslesen aus der DB funktioniert übrigens mit jeder Dateigröße relativ Zügig (2-3 Sekunden, dann sind die 7,5 MB aus den beiden großen Files da).

Woran könnte das liegen?

Edit: Update. Urgs. Wenn ich den Oracle Client verwende und nicht den Direct-Modes der Corelab Komponenten sind die 5MB in 30 Sekunden oben. Blöderweise ist Vorgabe, dass auf den Clients der Ora-Client nicht installiert werden darf. Kann man das irgendwie pimpen?
Sebastian Gingter
Phoenix - 不死鳥, Microsoft MVP, Rettungshundeführer
Über mich: Sebastian Gingter @ Thinktecture Mein Blog: https://gingter.org
  Mit Zitat antworten Zitat
Elvis

Registriert seit: 25. Nov 2005
Ort: München
1.909 Beiträge
 
Delphi 2010 Professional
 
#6

Re: Blobs nur bis 8KB?

  Alt 26. Feb 2007, 10:01
Zitat von Phoenix:
Edit: Update. Urgs. Wenn ich den Oracle Client verwende und nicht den Direct-Modes der Corelab Komponenten sind die 5MB in 30 Sekunden oben.
Deshalb benutze ich den nicht. Ist echt saugeil eine wirklich managed Client Lib für Oracle zu haben, aber da wo Ora spass macht hören dir CR Kompos auf...
Zitat:
Blöderweise ist Vorgabe, dass auf den Clients der Ora-Client nicht installiert werden darf. Kann man das irgendwie pimpen?
Klicke mal auf meinen User und suche in den Beiträgen nach "Instant client".


Edit: Der ODP ist bei LOBS nochmal etwa 3-mal so schnell wie der OraClient von MS. Die wollten wahrscheinlich damit verbergen wie abartig lahm der SQL Server mit LOBs umgeht.
Robert Giesecke
I’m a great believer in “Occam’s Razor,” the principle which says:
“If you say something complicated, I’ll slit your throat.”
  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 21:01 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