Erste Schritte mit der Volltextsuche

Gilt für:SQL ServerAzure SQL-DatenbankAzure SQL Managed Instance

Bei SQL Server-Datenbanken werden die Volltexte standardmäßig aktiviert. Bevor Sie Volltextabfragen jedoch ausführen können, müssen Sie einen Volltextkatalog und einen Volltextindex für die Tabellen oder indizierten Sichten, die Sie suchen möchten, erstellen.

Volltextsuche in zwei Schritten einrichten

Es gibt zwei grundlegende Schritte zum Einrichten der Volltextsuche:

  1. Erstellen eines Volltextkatalogs.
  2. Erstellen eines Volltextindex für Tabellen oder eine indizierte Sicht, die Sie durchsuchen möchten.

Jeder Volltextindex muss einem Volltextkatalog angehören. Sie können einen separaten Textkatalog für jeden Volltextindex erstellen oder einem Katalog mehrere Volltextindizes zuordnen. Ein Volltextkatalog ist ein virtuelles Objekt und gehört keiner Dateigruppe an. Der Katalog ist ein logisches Konzept, das auf eine Gruppe von Volltextindizes verweist.

Hinweis

Diese Schritte setzen voraus, dass Sie die optionalen Komponenten der Volltextsuche während der Installation von SQL Server installiert haben. Wenn dies nicht der Fall ist, müssen Sie SQL Server-Setup erneut ausführen, um sie hinzuzufügen.

Einrichten der Volltextsuche mithilfe eines Assistenten

Zum Einrichten der Volltextsuche mithilfe eines Assistenten finden Sie unter Verwenden des Volltextindizierungs-Assistenten weitere Informationen.

Einrichten der Volltextsuche mit Transact-SQL

Im folgenden zweiteiligen Beispiel wird ein Volltextkatalog mit Namen AdvWksDocFTCat in der AdventureWorks-Datenbank erstellt, und anschließend wird ein Volltextindex für die Tabelle Document in der Beispieldatenbank erstellt. Diese Anweisung erstellt den Volltextkatalog im bei der Installation angegebenen Standardverzeichnis. Der Ordner mit dem Namen AdvWksDocFTCat befindet sich im Standardverzeichnis.

  1. Im Beispiel wird eine AdvWksDocFTCatCREATE FULLTEXT CATALOG -Anweisung verwendet, um einen Volltextkatalog mit dem Namen zu erstellen:

    USE AdventureWorks;  
    GO  
    CREATE FULLTEXT CATALOG AdvWksDocFTCat;  
    

    Weitere Informationen finden Sie unter Erstellen und Verwalten von Volltextkatalogen.

  2. Bevor Sie einen Volltextindex für die Document-Tabelle erstellen können, müssen Sie sicherstellen, dass die Tabelle über einen eindeutigen, einspaltigen Index verfügt, der keine NULL-Werte zulässt. Die folgende CREATE INDEX -Anweisung erstellt in der DocumentID-Spalte der Document-Tabelle den eindeutigen ui_ukDoc-Index:

    CREATE UNIQUE INDEX ui_ukDoc ON Production.Document(DocumentNode);  
    
  3. Löschen Sie den vorhandenen Volltextindex in der Document-Tabelle mithilfe der folgenden DROP FULLTEXT INDEX-Anweisung.

    DROP FULLTEXT INDEX ON Production.Document
    GO
    
  4. Nachdem Sie einen eindeutigen Schlüssel erstellt haben, können Sie in der Document -Tabelle einen Volltextindex erstellen, indem Sie die folgende CREATE FULLTEXT INDEX -Anweisung verwenden.

    CREATE FULLTEXT INDEX ON Production.Document  
    (  
        Document                         --Full-text index column name   
            TYPE COLUMN FileExtension    --Name of column that contains file type information  
            Language 2057                 --2057 is the LCID for British English  
    )  
    KEY INDEX ui_ukDoc ON AdvWksDocFTCat --Unique index  
    WITH CHANGE_TRACKING AUTO            --Population type;  
    GO  
    
    

    Die in diesem Beispiel definierte TYPE COLUMN gibt die Typspalte in der Tabelle an, die den Typ des Dokuments in der Spalte Document (binäre Spalte) enthält. In der Typspalte wird die vom Benutzer angegebene Dateierweiterung – „.doc“, „.xls“ usw. – für das Dokument der betreffenden Zeile gespeichert. Die Volltext-Engine verwendet die Erweiterung einer Zeile, um den richtigen Filter für die Analyse der Daten in dieser Zeile aufzurufen. Nachdem der Filter die binären Daten der Zeile analysiert hat, analysiert die angegebene Worttrennung den Inhalt. (In diesem Beispiel wird der Worttrennung für Englisch (Englisch) verwendet.) Weitere Informationen finden Sie unter Konfigurieren und Verwalten von Filtern für die Suche.

    Weitere Informationen finden Sie unter Erstellen und Verwalten von Volltextindizes.

Auswählen von Optionen für einen Volltextindex

Wählen Sie eine Sprache

Weitere Informationen zum Auswählen der Sprache für die Spalte finden Sie unter Auswählen einer Sprache beim Erstellen eines Volltextindex.

Wählen Sie eine Dateigruppe

Das Erstellen eines Volltextindex ist ziemlich E/A-intensiv. Zusammenfassend besteht sie aus dem Lesen von Daten aus SQL Server und dem anschließenden Verteilen der gefilterten Daten an den Volltextindex. Die beste Vorgehensweise besteht darin, einen Volltextindex in der Datenbankdateigruppe anzuordnen, die am besten für die Optimierung der E/A-Leistung geeignet ist, oder ordnen Sie die Volltextindizes in einer anderen Dateigruppe auf einem anderen Volume an.

Wählen Sie einen Volltextkatalog

Es ist zu empfehlen, Tabellen mit denselben Updatemerkmalen (z. B. geringe Anzahl an Änderungen gegenüber einer großen Anzahl an Änderungen oder Tabellen, die regelmäßig zu bestimmten Tageszeiten geändert werden) zu gruppieren und demselben Volltextkatalog zuzuweisen. Indem Sie Zeitpläne für Volltextkataloge einrichten, bleiben Volltextindizes mit den Tabellen synchronisiert, ohne dass sich dies in Phasen umfangreicher Datenbankaktivitäten negativ auf die Ressourcenverwendung des Datenbankservers auswirkt.

Berücksichtigen Sie die folgenden Richtlinien:

  • Wenn Sie eine Tabelle mit mehreren Millionen Zeilen indizieren, sollten Sie die Tabelle einem eigenen Volltextkatalog zuweisen.

  • Berücksichtigen Sie sowohl den Umfang der Änderungen in den Tabellen, die mit einem Volltextindex indiziert werden, als auch die Gesamtzahl der Tabellenzeilen. Wenn die Gesamtzahl der geänderten Zeilen zusammen mit der Anzahl an Zeilen, die während der letzten Volltextauffüllung in der Tabelle enthalten waren, mehrere Millionen umfasst, sollten Sie die Tabelle einem eigenen Volltextkatalog zuweisen.

Ordnen Sie einen eindeutigen Index zu

Wählen Sie stets den kleinsten eindeutigen Index, der verfügbar ist, als eindeutigen Volltextschlüssel aus (Ein 4-Byte-, ganzzahliger Index ist optimal.) Dadurch werden die ressourcen, die vom Microsoft Search-Dienst im Dateisystem benötigt werden, erheblich reduziert. Wenn Sie einen breiten Primärschlüssel verwenden (mehr als 100 Byte), sollten Sie erwägen, als eindeutigen Volltextschlüssel einen anderen eindeutigen Index in der Tabelle auszuwählen (oder einen anderen eindeutigen Index zu erstellen). Andernfalls kann die Volltextauffüllung nicht mehr fortgesetzt werden, wenn der eindeutige Volltextschlüssel die maximal zulässige Größe erreicht (900 Byte).

Zuordnen einer Stoppliste

Eine Stoppliste ist eine Liste von Stoppwörtern. Stoppwörter werden auch als Füllwörter bezeichnet. Jedem Volltextindex ist eine Stoppliste zugeordnet, und die Wörter der Stoppliste werden auf Volltextabfragen des Indexes angewendet. Standardmäßig ist der Systemstoppliste ein neuer Volltextindex zugeordnet. Sie können auch eine eigene Stoppliste erstellen und verwenden.

Die folgende CREATE FULLTEXT STOPLIST Transact-SQL-Anweisung erstellt beispielsweise eine neue Volltext-Stoppliste mit dem Namen myStoplist durch Kopieren aus der Systemstoppliste:

CREATE FULLTEXT STOPLIST myStoplist FROM SYSTEM STOPLIST;  
GO  

Die folgende ALTER FULLTEXT STOPLIST Transact-SQL-Anweisung ändert eine Stoppliste mit dem Namen "myStoplist", wobei das Wort "en" zuerst für Spanisch und dann für Französisch hinzugefügt wird:

ALTER FULLTEXT STOPLIST myStoplist ADD 'en' LANGUAGE 'Spanish';  
ALTER FULLTEXT STOPLIST myStoplist ADD 'en' LANGUAGE 'French';  
GO  

Weitere Informationen finden sie unter Konfigurieren und Verwalten von Stoppwörtern und Stopplisten für Volltextsuche.

Aktualisieren Sie einen Volltextindex

Wie normale SQL Server-Indizes können Volltextindizes automatisch aktualisiert werden, wenn Daten in den zugehörigen Tabellen geändert werden. Dies ist das Standardverhalten. Alternativ dazu können Sie die Volltextindizes auch manuell auf dem aktuellen Stand halten oder in bestimmten Abständen aktualisieren lassen. Auffüllen eines Volltextindex kann zeitaufwändig und ressourcenintensiv sein. Aus diesem Grund wird das Indexupdate meist als asynchroner Vorgang durchgeführt, der im Hintergrund ausgeführt wird und den Volltextindex jeweils nach Änderungen in der Basistabelle aktualisiert.

Das sofortige Aktualisieren eines Volltextindex nach jeder Änderung in der Basistabelle ist auch ressourcenintensiv. Bei sehr hohen Update-, Einfügungs- und Löschungsraten kann es deshalb zu einer Verringerung der Abfrageleistung kommen. In diesem Fall sollten Sie erwägen, eine manuelle Änderungsnachverfolgung und entsprechende Updates zu planen, um die zahlreichen Änderungen von Zeit zu Zeit zu bearbeiten, anstatt mit den Abfragen um Ressourcen zu wetteifern.

Weitere Informationen finden Sie unter Auffüllen von Volltextindizes.

Nächste Schritte

Nachdem Sie die SQL Server-Volltextsuche eingerichtet haben, können Sie mit dem Ausführen von Volltextabfragen beginnen. Weitere Informationen finden Sie unter Abfragen mit Volltextsuche.