開発Blog

Microsoft SqlServer で シーケンステーブルを扱う

投稿日:2022-03-07 更新日:

intra-mart Accel Platform では、SqlServerを利用する場合、JDBCの接続プロパティに selectMethod=cursor を設定します。
この接続プロパティを使用すると、問い合わせの結果セットの行が限定された数だけクライアント( intra-mart Accel Platform )のメモリに保持されます。これにより、大量のデータを保持することがないため、メモリの枯渇などを防止する効果があります。
intra-mart Accel Platform では、 この設定を必ず使用してください。

ただし、この設定により、以下の弊害が発生します。

一般的には、Microsoft SqlServerでシーケンステーブルを利用する場合、以下のSQL文を使用します。

SELECT NEXT VALUE FOR Seq1

TenantDatabase の API や IM-LogicDesigner の SQL定義を利用して、このSQL文を実行すると2回インクリメントされた値が取得されます。
これは、JDBC のメソッドを直接利用した場合でも同様です。

これを回避する方法として、以下のSQL文を利用することで、1回インクリメントされた値が取得できることを確認しています。

シーケンステーブル名がSeq1の場合

SELECT NEXT VALUE FOR Seq1 AS seq_no FROM sys.sequences WHERE name = 'Seq1

FROM句とWHERE句を記述することで、必ず1レコードのみが取得されるようにします。
これで、レコード取得時に1度だけ採番されます。

上記のSQL文は、調査した結果の一例です。

実際に使用される場合は、検証を行い、期待通りの結果となること確認してから、ご利用をお願いします。

-開発Blog

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

no image

SQL Server利用時の実行速度向上策について

SQLServerのJDBCドライバのパラメータ設定方法です。 このパラメータを設定すると、SQLServer利用時のJDBCプログラミングAPIであるjava.sql.PreparedStateme …

no image

intra-mart製品の外字対応方針について

<intra-mart製品の外字対応方針について> 以前より問い合わせの多いintra-mart製品の外字対応方針について資料をまとめましたので参考にしてください。 (1)BM/FW Ver.5 Fo …

no image

intra-mart Advent Calendar 2013 第6日:実は、認可設定状況確認(/tenant/authz/view) というかあるんですよ!

この記事は、intra-mart Advent Calendar 2013 第6日の記事です。 あまり知られていないであろう機能を紹介する今年のAdvent Calendar、今回は、あまり知られてい …

no image

Apache Solr & IM-ContentsSearch

こんにちは、開発本部の大西です。 先日開催された、Open intra-mart勉強会で弊社コンサルティングチームの清さんが発表した Apache SolrとIM-ContentsSearchの資料を …

no image

IM-Workflow 処理対象者プラグイン でこんなことできます。

初めまして。こんにちは。開発本部の阿部です。 今回は、私が担当している IM-Workflow の機能について書きたいと思います。 プログラミングガイドにも載っている情報なんですが、ご存知でない方も多 …