PostgreSQL でテーブルを処理するときに、SQL 言語のキーワードに似た列名が表示されることがあります。 PostgreSQL は列名を識別子ではなくキーワードとして解釈しようとする可能性があるため、クエリの作成時にエラーが発生する可能性があります。
この問題を解決するには、二重引用符を使用して列名を囲み、それによって列名をエスケープし、PostgreSQL がキーワードと間違えるのを防ぎます。
たとえば、次の表を考えてみましょう:
<code class="language-sql">CREATE TABLE my_table (id SERIAL PRIMARY KEY, name TEXT, year INTEGER);</code>
ここで、このテーブルに新しい行を挿入し、「年」列を特定の値に設定するとします。クエリを次のように記述するとします:
<code class="language-sql">INSERT INTO my_table (id, name, year) VALUES (1, 'John Doe', 1990);</code>
PostgreSQL がキーワードを予約語として解釈しようとするため、「year」キーワードの近くでエラーが発生します。
これを修正するには、「年」を二重引用符で囲むだけです:
<code class="language-sql">INSERT INTO my_table (id, name, "year") VALUES (1, 'John Doe', 1990);</code>
列名を引用符で囲むことにより、PostgreSQL にそれをキーワードではなく識別子として扱うように指示し、その値を正常に設定できるようにします。
PostgreSQL のドキュメントによると、「区切り識別子」または「引用符で囲まれた識別子」とは、二重引用符で囲まれた識別子です。これらは常に識別子として認識され、キーワードと間違われることはありません。これにより、エラーが発生することなくキーワードを列名またはテーブル名として使用できるようになります。
以上がPostgreSQL でキーワードのような列名をエスケープするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。