Zugreifen auf FileTables mit Datei-E/A-APIs

Gilt für:SQL Server

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.

  1. 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 GetFileNamespacePath (Transact-SQL) -Funktion 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.

  2. 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 betreffen.

Lesen von Dateien und Verzeichnissen in einer FileTable

Die Semantik zum Lesen der zugesicherten Isolation wird in SQL Server für alle Datei-E/A-Zugriffsvorgänge für Datenstrom- und Attributdaten erzwungen.

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 ist 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 irgendwelche Dateien oder Unterverzeichnisse 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 (VNNs) mit Always On-Verfügbarkeitsgruppen

Wenn die Datenbank, die FILESTREAM oder FileTable-Daten enthält, zu einer Always On-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 mit AlwaysOn-Verfügbarkeitsgruppen (SQL Server).

Teilupdates

Ein schreibbares Handle für FILESTREAM-Daten in einer FileTable mithilfe der GetFileNamespacePath (Transact-SQL) -Funktion kann verwendet werden, um direkte, teilweise 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. SQL Server kann jedoch interne Transaktionen verwenden, um die Sperr- oder Parallelitätsemantik für die FileTable-Daten zu erzwingen. 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ätskontrolle 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 Bemerkungen
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 SQL Server-Tabelle und Spaltenebene werden 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-Funktionen zur Änderungsnachverfolgung können 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