Änderungsverlauf verwenden

Mit dem BigQuery-Änderungsverlauf können Sie den Änderungsverlauf einer BigQuery-Tabelle verfolgen. Mit GoogleSQL-Funktionen können Sie bestimmte Arten von Änderungen sehen, die während eines bestimmten Zeitraums vorgenommen wurden, damit Sie inkrementelle Änderungen an einer Tabelle verarbeiten können. Wenn Sie wissen, welche Änderungen an einer Tabelle vorgenommen wurden, können Sie beispielsweise ein Tabellenreplikat inkrementell außerhalb von BigQuery pflegen und teure Kopien vermeiden.

Erforderliche Berechtigungen

Zum Aufrufen des Änderungsverlaufs einer Tabelle benötigen Sie die Berechtigung bigquery.tables.getData für diese Tabelle. Die folgenden vordefinierten IAM-Rollen (Identity and Access Management) enthalten diese Berechtigung:

  • roles/bigquery.dataViewer
  • roles/bigquery.dataEditor
  • roles/bigquery.dataOwner
  • roles/bigquery.admin

Wenn eine Tabelle Zugriffsrichtlinien auf Zeilenebene hat oder hatte, kann nur ein Tabellenadministrator auf Verlaufsdaten für die Tabelle zugreifen. Die Berechtigung bigquery.rowAccessPolicies.overrideTimeTravelRestrictions ist für die Tabelle erforderlich und in der vordefinierten IAM-Rolle roles/bigquery.admin enthalten.

Wenn eine Tabelle die Sicherheit auf Spaltenebene bietet, können Sie den Änderungsverlauf nur für die Spalten aufrufen, auf die Sie Zugriff haben.

Funktionen für den Änderungsverlauf

Mit den folgenden Funktionen können Sie den Änderungsverlauf einer Tabelle nachvollziehen:

Preise und Kosten

Für den Aufruf von Änderungsverlaufsfunktionen fallen BigQuery-Rechenkosten an. Sowohl die Funktion APPENDS als auch die Funktion CHANGES erfordern die Verarbeitung aller Daten, die in der Tabelle im angegebenen Zeitraum geschrieben wurden. Diese Verarbeitung gilt für alle Schreibvorgänge, einschließlich Anhänge- und Mutationsvorgänge. Wenn Sie die enable_change_history-Option einer Tabelle auf FALSE festlegen, wird die von APPENDS verarbeitete Datenmenge nicht reduziert.

Wenn Sie die Option enable_change_history für eine Tabelle auf TRUE festlegen, um die Funktion CHANGES zu verwenden, speichert BigQuery Metadaten zu Tabellenänderungen. Diese gespeicherten Metadaten verursachen zusätzliche BigQuery-Speicherkosten und BigQuery-Rechenkosten. Der abgerechnete Betrag hängt von der Anzahl und Art der an der Tabelle vorgenommenen Änderungen ab und ist in der Regel gering. Bei Tabellen mit vielen Änderungsoperationen, insbesondere großen Löschvorgängen, fallen am ehesten spürbare Kosten an.