![]() |
binäre Daten in Datenbank
Hallo zusammen,
ein Kollege von mir stellte mir folgende Frage: Zitat:
- bevorzugt oracle >= 7.3 - interbase - mssql - gleichwertige Anwendung: Es soll eine Datenbank erstellt werden in die jede Menge binärer Dateien verwaltet werden sollen (z.B. Grafiken wie gif, jpg, Audio wie wav, mp3, PowerPoint, Word, ...) Das wichtige daran ist, das in der Datenbank ein Vergleich auf Dupletten vorgenommen werden soll. Die Daten sollen verschlüsselt abgelegt werden (Letzeres sollte aber kein Problem sein) Frage: Wie bekomme ich die Dateien sinnvoll in eine Datenbank und auch wieder raus? Wie stelle ich einen sinnvollen Vergleich von Dateien an? Ist es sinnvoll ein zusätzliches Feld mit einem Hash (oder CRC32) anzulegen und darüber den Vergleich zu machen, oder kann die Datenbank einen direkten Vergleich? (Performance?)
Code:
Vieleicht hat ja jemand von Euch damit Erfahrung / Ideen.
...where BlobFeld1 = BlobFeld2...
Für eine Antwort bedanke ich mich schon mal im Voraus. (°¿°) MaBuSE |
Hallo
Bei Microsoft SQLServer und Sybase SQLAnywhere können solche Datenbuffers angelegt werden, indem man die Type binary, varbinary oder image verwendet. Alle diese Typen werden in Delphi als Blob's angesprochen. Eine Sortierung ist auf diesen Felder jedoch nicht möglich (oder ich habe noch nie etwas davon gelesen!). Das Suchen in solchen feldern ist recht trickreich, ist aber möglich. Dafür muss man einen Vergleich mit Hex-Codes machen. Beispiel
Code:
Grosse Texte (z.B. grösser als 4k) können in einem Feld vom Type text abgelegt werden. In solchen Feldern kann mit alle String-Suchoperatoren gearbeitet werden. Für das Sortieren muss aber der Text geschnitten werden z.B. ORDER BY Convert(Varchar(255), LongText)
SELECT * FROM Test
WHERE BinField = 0xA50056..... Gruss Xaver |
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:26 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