48.16.6. PostgreSQL ケース


JdbcAggregationRepository で使用される楽観的ロックで問題が発生する可能性がある特別なデータベースがあります。PostgreSQL は、データの整合性違反の例外の場合(SQLState 23505)で接続を無効とマークします。これにより、ネストされたトランザクション内で接続が事実上使用できなくなります。詳細は、ドキュメント を参照してください。

org.apache.camel.processor.aggregate.jdbc.PostgresAggregationRepositoryJdbcAggregationRepository を拡張し、楽観的なロック動作を提供する特別な INSERT ..ON CONFLICT .. ステートメントを使用します。

このステートメントは(デフォルトの集約テーブル定義を含む)です。

INSERT INTO aggregation (id, exchange) values (?, ?) ON CONFLICT DO NOTHING
Copy to Clipboard Toggle word wrap

詳細については、PostgreSQL のドキュメント を参照してください。

この句を使用すると、java.sql.PreparedStatement.executeUpdate () 呼び出しは、SQLState=23505 で SQLException を出力する代わりに 0 を返します。追加の処理は、一般的な JdbcAggregationRepository とまったく同じですが、PostgreSQL 接続を無効としてマークする必要はありません。

トップに戻る
Red Hat logoGithubredditYoutubeTwitter

詳細情報

試用、購入および販売

コミュニティー

Red Hat ドキュメントについて

Red Hat をお使いのお客様が、信頼できるコンテンツが含まれている製品やサービスを活用することで、イノベーションを行い、目標を達成できるようにします。 最新の更新を見る.

多様性を受け入れるオープンソースの強化

Red Hat では、コード、ドキュメント、Web プロパティーにおける配慮に欠ける用語の置き換えに取り組んでいます。このような変更は、段階的に実施される予定です。詳細情報: Red Hat ブログ.

会社概要

Red Hat は、企業がコアとなるデータセンターからネットワークエッジに至るまで、各種プラットフォームや環境全体で作業を簡素化できるように、強化されたソリューションを提供しています。

Theme

© 2025 Red Hat