テーブル、データベース、および列の名前 - Amazon Athena

テーブル、データベース、および列の名前

Athena での命名には以下のヒントを参考にしてください。

Athena のテーブル名とテーブルの列名は小文字にする必要があります。

Apache Spark を使用する場合は、テーブル名とテーブルの列名を小文字にする必要があります。Athena では大文字と小文字を区別せず、テーブル名と列名を小文字に変換しますが、Spark には最初から小文字のテーブル名と列名が必要です。

大小文字が混在する列名 (profileURI) や大文字の列名が含まれているクエリは無効です。

特殊文字

アンダースコア (_) を除く特殊文字はサポートされていません。詳細については、Apache Hive LanguageManual DDL ドキュメントを参照してください。

重要

アンダースコアを除く特殊文字を含むテーブル、ビュー、データベース、または列の名前は、バックティック (`) 文字で囲むことで作成できますが、それを参照する後続の DDL または DML クエリは失敗する可能性があります。

アンダースコアで始まる名前

アンダースコアで始まるテーブル名、ビュー名、列名はバックティックで囲みます。以下に例を示します。

CREATE EXTERNAL TABLE IF NOT EXISTS `_myunderscoretable`( `_id` string, `_index` string) LOCATION 's3://my-athena-data/'

数字で始まるテーブル、ビュー、または列の名前

SELECTCTAS、または VIEW クエリでは、数字で始まるテーブル、ビュー、列名などの識別子を引用符で囲みます。以下に例を示します。

CREATE OR REPLACE VIEW "123view" AS SELECT "123columnone", "123columntwo" FROM "234table"

予約語

Athena の特定の予約語は、エスケープする必要があります。DDL ステートメントで予約キーワードをエスケープするには、バックティック (`) で囲みます。SQL の SELECT ステートメントや ビュー のクエリで予約キーワードをエスケープするには、二重引用符 ('') で囲みます。

詳細については、「予約キーワード」を参照してください。