Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
Erstellen von Tabellen basierend auf verschlüsselten Datensätzen in Amazon S3
Wenn Sie eine Tabelle erstellen, zeigen Sie Athena an, dass ein Datensatz in Amazon S3 verschlüsselt ist. Dies ist nicht erforderlich, wenn Sie - verwendenSSE. KMS Sowohl für SSE -S3 als auch für die AWS KMS Verschlüsselung bestimmt Athena, wie der Datensatz entschlüsselt und die Tabelle erstellt werden soll, sodass Sie keine Schlüsselinformationen angeben müssen.
Benutzer, die Abfragen ausführen möchten. einschließlich des Benutzers, der die Tabelle erstellt, müssen die zuvor in diesem Thema beschriebenen Berechtigungen haben.
Wichtig
Wenn Sie Amazon EMR zusammen mit verwenden, EMRFS um verschlüsselte Parquet-Dateien hochzuladen, müssen Sie mehrteilige Uploads deaktivieren, indem Sie auf einstellenfs.s3n.multipart.uploads.enabled
. false
Wenn Sie dies nicht tun, kann Athena die Länge der Parquet-Datei nicht bestimmen und es tritt ein HIVE_ CANNOT _ OPEN _ SPLIT -Fehler auf. Weitere Informationen finden Sie unter Mehrteiligen Upload für Amazon S3 konfigurieren im Amazon EMR Management Guide.
Führen Sie einen der folgenden Schritte aus, um anzugeben, dass ein Datensatz in Amazon S3 verschlüsselt ist. Dieser Schritt ist nicht erforderlich, wenn SSE - verwendet KMS wird.
-
Verwenden Sie in einer CREATETABLEAnweisung eine
TBLPROPERTIES
Klausel, die Folgendes angibt'has_encrypted_data'='true'
, wie im folgenden Beispiel.CREATE EXTERNAL TABLE 'my_encrypted_data' ( `n_nationkey` int, `n_name` string, `n_regionkey` int, `n_comment` string) ROW FORMAT SERDE 'org.apache.hadoop.hive.ql.io.parquet.serde.ParquetHiveSerDe' STORED AS INPUTFORMAT 'org.apache.hadoop.hive.ql.io.parquet.MapredParquetInputFormat' LOCATION 's3://amzn-s3-demo-bucket/
folder_with_my_encrypted_data
/' TBLPROPERTIES ( 'has_encrypted_data'='true') -
Verwenden Sie den JDBCTreiber und legen Sie den
TBLPROPERTIES
Wert fest, wie im vorherigen Beispiel gezeigt, wennstatement.executeQuery()
Sie die CREATETABLEAnweisung ausführen. -
Wenn Sie die Athena-Konsole zum Erstellen einer Tabelle mit einem Formular verwenden und einen Tabellenspeicherort angeben, wählen Sie die Option Verschlüsselter Datensatz aus.
In der Tabellenliste der Athena-Konsole zeigen verschlüsselte Tabellen ein schlüsselförmiges Symbol an.