Wenn Sie strukturierte Daten mit der Google Cloud Console importieren, erkennt Vertex AI Search das Schema automatisch. Sie können entweder dieses automatisch erkannte Schema in Ihrer Engine verwenden oder über die API ein Schema bereitstellen, um die Struktur der Daten anzugeben.
Wenn Sie ein Schema bereitstellen und es später mit einem neuen Schema aktualisieren, muss das neue Schema abwärtskompatibel mit dem ursprünglichen Schema sein. Andernfalls schlägt die Schemaaktualisierung fehl.
Weitere Informationen zum Schema finden Sie unter dataStores.schemas.
Möglichkeiten zum Bereitstellen des Schemas für Ihren Datenspeicher
Es gibt verschiedene Möglichkeiten, das Schema für strukturierte Daten zu bestimmen.
Automatische Erkennung und Bearbeitung: Lassen Sie Vertex AI Search das erste Schema automatisch erkennen und vorschlagen. Anschließend verfeinern Sie das Schema über die Console-Oberfläche. Google empfiehlt dringend, nach der automatischen Erkennung der Felder allen wichtigen Feldern Schlüsselattribute zuzuordnen.
Dieser Ansatz wird verwendet, wenn Sie der Anleitung für strukturierte Daten in der Google Cloud Console unter Suchdatenspeicher erstellen und Benutzerdefinierten Empfehlungsdatenspeicher erstellen folgen.
Schema als JSON-Objekt bereitstellen: Stellen Sie das Schema als JSON-Objekt für Vertex AI Search bereit. Sie müssen ein korrektes JSON-Objekt vorbereitet haben. Ein Beispiel für ein JSON-Objekt finden Sie unter Beispiel für ein Schema als JSON-Objekt. Nachdem Sie das Schema erstellt haben, laden Sie Ihre Daten entsprechend hoch.
Dieser Ansatz kann verwendet werden, wenn Sie einen Datenspeicher über die API mit einem curl-Befehl (oder einem Programm) erstellen. Ein Beispiel finden Sie unter Einmaliger Import aus BigQuery. Weitere Informationen finden Sie in der Anleitung Eigenes Schema als JSON-Objekt bereitstellen.
Media: Stellen Sie Ihre Daten im von Google definierten Schema bereit. Wenn Sie einen Datenspeicher für Media erstellen, können Sie das vordefinierte Schema von Google verwenden. Wenn Sie diese Option auswählen, wird davon ausgegangen, dass Sie Ihr JSON-Objekt im Format unter Mediendokumente und Datenspeicher strukturiert haben. Standardmäßig werden dem Schema durch die automatische Erkennung alle neuen Felder hinzugefügt, die während der Datenerfassung gefunden werden.
Dieser Ansatz wird verwendet, wenn Sie der Anleitung unter Media-App und Datenspeicher erstellen folgen. Das ist auch der Ansatz in den Anleitungen Erste Schritte: Medienempfehlungen und Erste Schritte: Mediensuche, in denen die Beispieldaten im vordefinierten Google-Schema bereitgestellt werden.
Media: Automatische Erkennung und Bearbeitung, wobei die erforderlichen Media-Properties berücksichtigt werden. Bei Media-Daten können Sie die automatische Erkennung verwenden, um das Schema vorschlagen zu lassen und es dann zu bearbeiten. Ihr JSON-Objekt muss Felder enthalten, die den Media-Schlüsseleigenschaften
title,uri,category,media_durationundmedia_available_timezugeordnet werden können.Dieser Ansatz wird verwendet, wenn Sie Media-Daten über dieGoogle Cloud Console importieren und die Media-Daten nicht dem von Google definierten Schema entsprechen.
Media: Eigenes Schema als JSON-Objekt bereitstellen Stellen Sie das Schema als JSON-Objekt für Vertex AI Search bereit. Sie müssen ein korrektes JSON-Objekt vorbereitet haben. Das Schema muss Felder enthalten, die den Media-Schlüsselattributen
title,uri,category,media_durationundmedia_available_timezugeordnet werden können.Ein Beispiel für ein JSON-Objekt finden Sie unter Beispiel für ein Schema als JSON-Objekt. Nachdem Sie das Schema erstellt haben, laden Sie Ihre Media-Daten entsprechend hoch.
Bei diesem Ansatz verwenden Sie die API über einen curl-Befehl (oder ein Programm). Weitere Informationen finden Sie in der Anleitung Eigenes Schema als JSON-Objekt bereitstellen.
Informationen zur automatischen Erkennung und Bearbeitung
Wenn Sie mit dem Importieren von Daten beginnen, werden in Vertex AI Search die ersten importierten Dokumente als Beispiele verwendet. Anhand dieser Dokumente wird ein Schema für die Daten vorgeschlagen, das Sie dann überprüfen oder bearbeiten können.
Wenn Felder, die Sie Schlüsselattributen zuordnen möchten, in den Beispieldokumenten nicht vorhanden sind, können Sie sie manuell hinzufügen, wenn Sie das Schema überprüfen.
Wenn Vertex AI Search später beim Datenimport zusätzliche Felder findet, werden diese Felder trotzdem importiert und dem Schema hinzugefügt. Wenn Sie das Schema bearbeiten möchten, nachdem alle Daten importiert wurden, lesen Sie den Abschnitt Schema aktualisieren.
Beispielschema als JSON-Objekt
Sie können Ihr eigenes Schema im Format eines JSON-Schemas definieren. Das ist eine deklarative Open-Source-Sprache zum Definieren, Annotieren und Validieren von JSON-Dokumenten. Beispiel für eine gültige JSON-Schema-Annotation:
{ "$schema": "https://json-schema.org/draft/2020-12/schema", "type": "object", "dynamic": "true", "datetime_detection": true, "geolocation_detection": true, "properties": { "title": { "type": "string", "keyPropertyMapping": "title", "retrievable": true, "completable": true }, "description": { "type": "string", "keyPropertyMapping": "description" }, "categories": { "type": "array", "items": { "type": "string", "keyPropertyMapping": "category" } }, "uri": { "type": "string", "keyPropertyMapping": "uri" }, "brand": { "type": "string", "indexable": true, "dynamicFacetable": true }, "location": { "type": "geolocation", "indexable": true, "retrievable": true }, "creationDate": { "type": "datetime", "indexable": true, "retrievable": true }, "isCurrent": { "type": "boolean", "indexable": true, "retrievable": true }, "runtime": { "type": "string", "keyPropertyMapping": "media_duration" }, "releaseDate": { "type": "string", "keyPropertyMapping": "media_available_time" } } }
Wenn Sie ein Medienschema definieren, müssen Sie Felder einfügen, die den Media-Schlüsselattributen zugeordnet werden können. Diese wichtigen Attribute werden in diesem Beispiel gezeigt.
Dieses Beispielschema enthält u. a. die folgenden Felder:
dynamic: Wenndynamicauf den Stringwert"true"gesetzt ist, werden alle neuen Attribute, die in den importierten Daten gefunden werden, dem Schema hinzugefügt. Wenndynamicauf"false"gesetzt ist, werden neue Attribute in importierten Daten ignoriert. Die Attribute werden dem Schema nicht hinzugefügt die Werte werden nicht importiert.Angenommen, ein Schema hat zwei Attribute:
titleunddescription. Sie laden Daten hoch, die Attribute fürtitle,descriptionundratingenthalten. Wenndynamic"true"ist, werden das Attribut und die Daten für „rating“ importiert. Wenndynamic"false"ist, werden die Attribute fürratingnicht importiert,titleunddescriptionaber schon.Der Standardwert ist
"true".datetime_detection: Wenndatetime_detectionauf den booleschen Werttruegesetzt ist, wird der Schematyp beim Import von Daten im Datums-/Uhrzeitformat aufdatetimefestgelegt. Die unterstützten Formate sind RFC 3339 und ISO 8601.Beispiel:
2024-08-05 08:30:00 UTC2024-08-05T08:30:00Z2024-08-05T01:30:00-07:002024-08-052024-08-05T08:30:00+00:00
Wenn
datatime_detectionauf den booleschen Wertfalsegesetzt ist, wird der Schematyp beim Import von Daten im Datums-/Uhrzeitformat aufstringfestgelegt.Der Standardwert ist
true.geolocation_detection: Wenngeolocation_detectionauf den booleschen Werttruegesetzt ist, wird der Schematyp beim Import von Daten im Format für die Standortbestimmung aufgeolocationfestgelegt. Daten werden als Standortbestimmung erkannt, wenn es sich um ein Objekt mit einer Breitengrad- und einer Längengradzahl oder um ein Objekt mit einem Adressstring handelt.Beispiel:
"myLocation": {"latitude":37.42, "longitude":-122.08}"myLocation": {"address": "1600 Amphitheatre Pkwy, Mountain View, CA 94043"}
Wenn
geolocation_detectionauf den booleschen Wertfalsegesetzt ist, wird der Schematyp beim Import von Daten im Format für die Standortbestimmung aufobjectfestgelegt.Der Standardwert ist
true.keyPropertyMapping: Ein Feld, in dem vordefinierte Suchbegriffe kritischen Feldern in Ihren Dokumenten zugeordnet werden, um ihre semantische Bedeutung zu verdeutlichen. Mögliche Werte sindtitle,description,uriundcategory. Der Feldname muss nicht mit dem WertkeyPropertyValuesübereinstimmen. Für ein Feld mit dem Namenmy_titlekönnen Sie beispielsweise das FeldkeyPropertyValuesmit dem Werttitleeinfügen.Bei Datenspeichern für die Suche sind mit
keyPropertyMappinggekennzeichnete Felder standardmäßig indexierbar und suchbar, aber nicht abrufbar, vervollständigbar oder als dynamicFacetable-Attribut verwendbar. Das bedeutet, dass Sie die Felderindexableodersearchablenicht zusammen mit dem FeldkeyPropertyValuesangeben müssen, um das erwartete Standardverhalten zu erhalten.type: Der Typ des Felds. Dies ist ein Stringwert, und zwardatetime,geolocationoder einer der einfachen Typen (integer,boolean,object,array,numberoderstring).
Die folgenden Attributfelder gelten nur für Such-Apps:
retrievable: Gibt an, ob dieses Feld in einer Suchantwort zurückgegeben werden kann. Dies kann für Felder vom Typnumber,string,boolean,integer,datetimeundgeolocationfestgelegt werden. Es können maximal 50 Felder als abrufbar festgelegt werden. Benutzerdefinierte Felder undkeyPropertyValues-Felder können standardmäßig nicht abgerufen werden. Wenn Sie ein Feld abrufbar machen möchten, fügen Sie"retrievable": truein das Feld ein.indexable: Gibt an, ob dieses Feld in der MethodeservingConfigs.searchgefiltert, facettiert, optimiert oder sortiert werden kann. Dies kann für Felder vom Typnumber,string,boolean,integer,datetimeundgeolocationfestgelegt werden. Es können maximal 50 Felder als indexierbar festgelegt werden. Benutzerdefinierte Felder sind standardmäßig nicht indexierbar, mit Ausnahme von Feldern, die das FeldkeyPropertyMappingenthalten. Wenn Sie ein Feld indexierbar machen möchten, fügen Sie"indexable": truein das Feld ein.dynamicFacetable: Gibt an, dass das Feld als dynamisches Attribut verwendet werden kann. Dies kann für Felder des Typsnumber,string,booleanundintegerfestgelegt werden. Damit ein Feld als dynamisches Attribut verwendbar ist, muss es auch indexierbar sein. Fügen Sie dazu"dynamicFacetable": trueund"indexable": truein das Feld ein.searchable: Gibt an, ob dieses Feld rückwärts indexiert werden kann, um unstrukturierte Textanfragen abzugleichen. Dieser Wert kann nur für Felder vom Typstringfestgelegt werden. Es können maximal 50 Felder als suchbar festgelegt werden. Benutzerdefinierte Felder sind standardmäßig nicht suchbar, mit Ausnahme von Feldern, die das FeldkeyPropertyMappingenthalten. Wenn Sie ein Feld suchbar machen möchten, fügen Sie"searchable": truein das Feld ein.completable: Gibt an, ob dieses Feld als automatisch vervollständigter Vorschlag zurückgegeben werden kann. Dieser Wert kann nur für Felder vom Typstringfestgelegt werden. Wenn ein Feld vervollständigbar werden soll, fügen Sie"completable": truehinzu.
Außerdem gilt das folgende Feld nur für Empfehlungs-Apps:
recommendationsFilterable: Gibt an, dass das Feld in einem Empfehlungsfilterausdruck verwendet werden kann. Allgemeine Informationen zum Filtern von Empfehlungen finden Sie unter Empfehlungen filtern.... "genres": { "type": "string", "recommendationsFilterable": true, ... },
Eigenes Schema als JSON-Objekt bereitstellen
Wenn Sie ein eigenes Schema bereitstellen möchten, erstellen Sie einen Datenspeicher, der ein leeres Schema enthält. Anschließend aktualisieren Sie das Schema und stellen Ihr Schema als JSON-Objekt bereit. Gehen Sie so vor:
Bereiten Sie das Schema als JSON-Objekt vor. Verwenden Sie dazu das Beispielschema als JSON-Objekt als Leitfaden.
Erstellen Sie einen Datenspeicher.
curl -X POST \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ -H "Content-Type: application/json" \ -H "X-Goog-User-Project: PROJECT_ID" \ "https://discoveryengine.googleapis.com/v1/projects/PROJECT_ID/locations/global/collections/default_collection/dataStores?dataStoreId=DATA_STORE_ID" \ -d '{ "displayName": "DATA_STORE_DISPLAY_NAME", "industryVertical": "INDUSTRY_VERTICAL" }'Ersetzen Sie Folgendes:
PROJECT_ID: die ID Ihres Projekts in Google Cloud .DATA_STORE_ID: Die ID des Vertex AI Search-Datenspeichers, den Sie erstellen möchten. Diese ID darf nur Kleinbuchstaben, Ziffern, Unterstriche und Bindestriche enthalten.DATA_STORE_DISPLAY_NAME: Der Anzeigename des Vertex AI Search-Datenspeichers, den Sie erstellen möchten.INDUSTRY_VERTICAL:GENERICoderMEDIA
Verwenden Sie die API-Methode schemas.patch, um Ihr neues JSON-Schema als JSON-Objekt bereitzustellen.
curl -X PATCH \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ -H "Content-Type: application/json" \ "https://discoveryengine.googleapis.com/v1beta/projects/PROJECT_ID/locations/global/collections/default_collection/dataStores/DATA_STORE_ID/schemas/default_schema" \ -d '{ "structSchema": JSON_SCHEMA_OBJECT }'Ersetzen Sie Folgendes:
PROJECT_ID: die ID Ihres Projekts in Google Cloud .DATA_STORE_ID: Die ID des Vertex AI Search-Datenspeichers.JSON_SCHEMA_OBJECT: Ihr neues JSON-Schema als JSON-Objekt. Beispiel:{ "$schema": "https://json-schema.org/draft/2020-12/schema", "type": "object", "properties": { "title": { "type": "string", "keyPropertyMapping": "title" }, "categories": { "type": "array", "items": { "type": "string", "keyPropertyMapping": "category" } }, "uri": { "type": "string", "keyPropertyMapping": "uri" } } }
Optional: Überprüfen Sie das Schema, indem Sie die Schritte unter Schemadefinition ansehen ausführen.
Nächste Schritte
- Suchanwendung erstellen
- Empfehlungs-App erstellen
- Media-App erstellen
- Schemadefinition ansehen
- Schema aktualisieren