同じ列名を持つテーブルから列を取得する場合、テーブル エイリアスを使用したクエリが効果的です。ただし、resultSet.getString("a.column") のような構文を使用してこれらの列にアクセスすると、期待どおりに動作しない可能性があります。
問題の理解
JDBC は本質的に列に次の名前を付けます。基礎となる SQL クエリで指定されます。これにはテーブル エイリアスの概念がなく、クエリ内に存在する列名に基づいて列を直接取得します。
ソリューション オプション:
2 つの実用的なソリューションが存在します:
オプション 1: 列のエイリアスクエリ
列のエイリアスを使用するようにクエリを変更すると、そのエイリアスによる各列への一意のアクセスが可能になります。たとえば、次のクエリを考えてみます。
SELECT a.columnName AS columnName_a, b.columnName AS columnName_b FROM table1 AS a, table2 AS b WHERE (condition);
Java コードでは、次のエイリアスを使用して列にアクセスできます。
resultSet.getString("columnName_a"); resultSet.getString("columnName_b");
オプション 2: 位置による列へのアクセス
あるいは、結果セット内の位置によって列にアクセスすることもできます。 JDBC は、1 から始まる 1 から始まるインデックスを使用します:
resultSet.getString(1); // First column resultSet.getString(2); // Second column
推奨事項
どちらの方法も実行可能ですが、通常は列のエイリアシング (オプション 1) が推奨されます。これにより、列への明示的かつ明確なアクセスが提供され、インデックス関連のエラーのリスクが軽減され、コードがより読みやすく保守しやすくなります。
以上がJDBC ResultSet とテーブル エイリアスを使用して同じ名前の列にアクセスするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。