Zugreifen auf FileTables mit Datei-E/A-APIs
Beschreibt, wie Dateisystem-E/A in einer FileTable funktioniert.
Erste Schritte mit Datei-E/A-APIs mit FileTables
Die primäre Verwendung von FileTables wird durch das Windows-Dateisystem und Datei-E/A-APIs erwartet. FileTables unterstützt den nicht transaktionalen Zugriff durch den umfangreichen Satz verfügbarer Datei-E/A-APIs.
Datei-E/A-API-Zugriff beginnt in der Regel, indem er einen logischen UNC-Pfad für die Datei oder das Verzeichnis anfordert. Anwendungen können eine Transact-SQL-Anweisung mit der Funktion GetFileNamespacePath (Transact-SQL) verwenden, um den logischen Pfad für die Datei oder das Verzeichnis abzurufen. Weitere Informationen finden Sie unter Work with Directories and Paths in FileTables.
Von der Anwendung wird dieser logische Pfad anschließend verwendet, um ein Handle für die Datei oder das Verzeichnis abzurufen und etwas mit dem Objekt auszuführen. Der Pfad kann an jede unterstützte Dateisystem-API-Funktion, z. B. CreateFile() oder CreateDirectory(), übergeben werden, um eine Datei zu erstellen oder zu öffnen und ein Handle abzurufen. Das Handle kann verwendet werden, um dann Daten zu streamen, aufzuzählen oder Verzeichnisse zu organisieren oder um Dateiattribute zu erhalten bzw. festzulegen oder umd Dateien oder Verzeichnisse usw. zu löschen.
Erstellen von Dateien und Verzeichnissen in einer FileTable
Eine Datei oder ein Verzeichnis kann in einer FileTable mithilfe von Datei-E/A-APIs, beispielsweise CreateFile oder CreateDirectory, erstellt werden.
Sämtliche CREATION_DISPOSITION-Flags, Freigabemodi und Zugriffsmodi werden unterstützt. Dies schließt die Erstellung, Löschung und direkte Änderung von Dateien ein. Aktualisierungen von Dateinamespaces (z. B. Erstellen und Löschen von Verzeichnissen, Umbenennungs- und Verschiebevorgänge) werden ebenfalls unterstützt.
Das Erstellen einer neuen Datei oder eines neuen Verzeichnisses entspricht der Erstellung einer neuen Zeile in der zugrunde liegenden FileTable.
Bei Dateien werden die Datenstromdaten in der file_stream -Spalte gespeichert, wohingegen diese Spalte bei Verzeichnissen NULL entspricht.
Für Dateien enthält die is_directory -Spalte den Wert false. Für Verzeichnisse enthält diese Spalte den Wert true.
Freigabe und Parallelität des Zugriffs werden erzwungen, wenn mehrere gleichzeitige Datei-E/A-Vorgänge oder Transact-SQL-Vorgänge die gleiche Datei oder dasselbe Verzeichnis in der Hierarchie beeinflussen.
Lesen von Dateien und Verzeichnissen in einer FileTable
Alle Datei-E/A-Zugriffsvorgänge (für Datenstrom- und Attributdaten) verfügen über eine Read Committed-Isolationssemantik für diese Daten in SQL Server .
Schreiben und Aktualisieren von Dateien und Verzeichnissen in einer FileTable
Alle Datei-E/A-Schreib-/Updatevorgänge auf einer FileTable sind nicht transaktional. Das heißt, keine SQL Server -Transaktion wird an diese Vorgänge gebunden, und es werden keine ACID-Garantien bereitgestellt.
Alle Datei-E/A-Streaming- bzw. direkten Updates werden für die FileTable unterstützt.
Updates der FILESTREAM-Daten oder -attribute über die Datei-E/A-APIs haben Updates der entsprechenden file_stream - und Dateiattributspalten in der FileTable zur Folge.
Löschen von Dateien und Verzeichnissen in einer FileTable
Jede Windows-Datei-E/A-API-Semantik wird erzwungen, wenn Sie eine Datei oder ein Verzeichnis löschen.
Beim Löschen eines Verzeichnisses tritt ein Fehler auf, wenn das Verzeichnis Unterverzeichnisse mit Dateien enthält.
Durch Löschen einer Datei oder eines Verzeichnisses wird die entsprechende Zeile aus der FileTable entfernt. Dies entspricht dem Löschen der Zeile über einen Transact-SQL-Vorgang.
Unterstützte Dateisystemvorgänge
FileTables unterstützen die Dateisystem-APIs, die sich auf die folgenden Dateisystemvorgänge beziehen:
Verzeichnisverwaltung
Dateiverwaltung
FileTables unterstützen die folgenden Vorgänge nicht:
Datenträgerverwaltung
Volumeverwaltung
Transaktions-NTFS
Weitere Überlegungen für Datei-E/A-Zugriff auf FileTables
Verwenden von virtuellen Netzwerknamen mit (VNNs) AlwaysOn-Verfügbarkeitsgruppen
Wenn die Datenbank, die FILESTREAM oder FileTable-Daten enthält, zu einer AlwaysOn-Verfügbarkeitsgruppe gehört, dann sollten bei allen Zugriffen auf FILESTREAM oder FileTable-Daten über die Dateisystem-APIs VNNs statt der Computernamen verwendet werden. Weitere Informationen finden Sie unter FILESTREAM und FileTable with AlwaysOn Availability Groups (SQL Server).
Teilupdates
Ein beschreibbares Handle, das für FILESTREAM-Daten in einer FileTable mithilfe der Funktion GetFileNamespacePath (Transact-SQL) abgerufen wird, kann verwendet werden, um direkte, partielle Aktualisierungen des FILESTREAM-Inhalts vorzunehmen. Dies steht im Gegensatz zu dem transaktiven FILESTREAM-Zugriff über ein Handle, das durch den OpenSQLFILESTREAM() -Befehl und durch das Übergeben eines expliziten Transaktionskontexts abgerufen wurde.
Transaktionssemantik
Wenn Sie mit Datei-E/A-APIs auf die Dateien in einer FileTable zugreifen, sind diese Vorgänge keinen Benutzertransaktionen zugeordnet und haben die folgenden zusätzlichen Eigenschaften:
Nicht transaktiver Zugriff auf FILESTREAM-Daten in einer FileTable ist keinen Transaktionen zugeordnet und verfügt daher nicht über eine spezifische Isolationssemantik. Von SQL Server wird jedoch möglicherweise Sperren- oder Parallelitätssemantik mithilfe von internen Transaktionen auf den FileTable-Daten erzwungen. Alle internen Transaktionen dieses Typs werden mit Read Committed-Isolation ausgeführt.
Es gibt keine ACID-Garantien für diese nicht transaktiven Vorgänge hinsichtlich FILESTREAM-Daten. Die Konsistenzgarantien ähneln denen für Dateiupdates, die von Anwendungen im Dateisystem erstellt wurden.
Für diese Änderungen ist kein Rollback möglich.
Auf die Spalte FILESTREAM in einer FileTable kann jedoch auch mit Transaktions-FILESTREAM-Zugriff zugegriffen werden, indem OpenSqlFileStream() aufgerufen wird. Diese Art von Zugriff kann vollständig transaktionsgebunden sein und berücksichtigt alle derzeit einheitlich unterstützten Transaktionen.
Gleichzeitigkeitssteuerung
SQL Server erzwingt die Parallelitätssteuerung für den FileTable-Zugriff zwischen Dateisystemanwendungen und zwischen Dateisystemanwendungen und Transact-SQL-Anwendungen. Diese Parallelitätssteuerung wird durch entsprechende Sperren in den FileTable-Zeilen erreicht.
Auslöser
Das Erstellen/Ändern/Löschen von Dateien/Verzeichnissen oder deren Attributen über das Dateisystem führt zu entsprechenden Einfüge-/Update-/Löschvorgängen in der FileTable. Alle zugeordneten Transact-SQL-DML-Trigger werden als Teil dieser Vorgänge ausgelöst.
In FileTables unterstützte Dateisystemfunktionalität
Funktion | Unterstützt | Kommentare |
---|---|---|
Oplocks | Ja | Ebene 2, Ebene 1, Batch- und Filter-Oplocks werden unterstützt. |
Erweiterte Attribute | Nein | |
Reparse Points | Nein | |
Persistente ACLs | Nein | |
Benannte Datenströme | Nein | |
Dateien von geringer Dichte | Ja | Geringe Dichte kann nur für Dateien festgelegt werden und wirkt sich auf die Speicherung des Datenstroms aus. Da FILESTREAM-Daten auf NTFS-Volumes gespeichert werden, unterstützt die Dateitabellenfunktion Sparsedateien, indem sie die Anforderungen an das NTFS-Dateisystem weiterleitet. |
Komprimierung | Ja | |
Verschlüsselung | Ja | |
TxF | Nein | |
Datei-IDs | Nein | |
Objekt-IDs | Nein | |
Symbolische Links | Nein | |
Harte Links | Nein | |
Kurze Namen | Nein | |
Benachrichtigungen über Verzeichnisänderungen | Nein | |
Bytebereichssperren | Ja | Anforderungen zur Bytebereichssperre werden an das NTFS-Dateisystem übergeben. |
Im Speicher abgebildete Dateien | Nein | |
Abbrechen von E/A | Ja | |
Security | Nein | Sicherheit auf Windows-Freigabeebene und Sicherheit auf SQL Server -Tabellen-/Spaltenebene wird erzwungen. |
USN-Journal | Nein | Metadatenänderungen an Dateien und Verzeichnissen in einer FileTable sind DML-Vorgänge in einer SQL Server -Datenbank. Daher werden sie in der entsprechenden Datenbankprotokolldatei protokolliert. Sie werden jedoch (abgesehen von Änderungen an der Größe) nicht im NTFS-USN-Journal protokolliert. SQL Server -Änderungsnachverfolgung kann verwendet werden, um ähnliche Informationen zu erfassen. |
Weitere Informationen
Laden von Dateien in FileTables
Verwenden von Verzeichnissen und Pfaden in FileTables
Zugreifen auf FileTables mit Transact-SQL
FileTable-DDL, Funktionen, gespeicherte Prozeduren und Sichten