Das Speichern verschiedener Dateitypen (z. B. .gif, .doc, .pdf) in einer Datenbank stellt eine große Herausforderung dar. Eine gängige Lösung besteht darin, Dateien in Byte-Arrays zu konvertieren und sie als Binärdaten zu speichern. Aber ist das die effizienteste Methode?
Diese Analyse konzentriert sich auf den VARBINARY(MAX)
Datentyp von SQL Server zum Speichern von Dateidaten.
Die databaseFilePut
-Funktion liest eine Datei, wandelt sie in ein Byte-Array um (unter Verwendung von FileStream
und BinaryReader
) und fügt dieses Array in die Raporty
-Spalte der VARBINARY(MAX)
-Tabelle ein.
Die Funktion databaseFileRead
ruft eine Datei aus der Datenbank ab und speichert sie an einem angegebenen Dateisystemspeicherort. Es liest das Byte-Array aus der Spalte VARBINARY(MAX)
, rekonstruiert die Datei und schreibt sie in den angegebenen Pfad.
Die databaseFileRead
-Funktion ermöglicht auch das Abrufen der Datei als MemoryStream
. Dies ermöglicht die In-Memory-Dateiverarbeitung, ohne dass ein temporärer Dateisystemspeicher erforderlich ist.
MemoryStream
DatenDie Funktion databaseFilePut
unterstützt das direkte Einfügen von MemoryStream
-Daten in die Spalte VARBINARY(MAX)
. Es konvertiert das MemoryStream
vor dem Einfügen in die Datenbank in ein Byte-Array.
Das obige ist der detaillierte Inhalt vonIst das Speichern von Dateien als Byte-Arrays in VARBINARY(MAX) von SQL Server eine effektive Datenbankspeicherlösung?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!