質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

トランザクション

トランザクションとは、関連・依存する処理を一連の不可分な処理単位として扱う処理方式を指します。トランザクションとして管理された処理は「すべて成功」か「すべて失敗」のいずれかであることが保証される。処理に失敗した場合は、一連の処理がロールバックされます。

Q&A

解決済

2回答

7121閲覧

[doma2]ループ処理内でのトランザクション管理について

KNovata

総合スコア8

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

トランザクション

トランザクションとは、関連・依存する処理を一連の不可分な処理単位として扱う処理方式を指します。トランザクションとして管理された処理は「すべて成功」か「すべて失敗」のいずれかであることが保証される。処理に失敗した場合は、一連の処理がロールバックされます。

0グッド

0クリップ

投稿2017/03/15 06:56

初めて質問させて頂きます。
初歩的なかもしれませんが、ご教示ください。

現在Doma2を使って開発をしています。
ループ処理内でトランザクション処理を行いたいとき、
以下のようにループ1回ごとにトランザクションを開始するのは問題があるのでしょうか?

java

1TransactionManager tm = AppConfig.singleton().getTransactionManager(); 2for(..; ..; ..) { 3 tm.required(() -> { 4 .. 何かしらの処理 5 }); 6} 7``` 8トランザクションの枯渇?のようなものが起きるのでしょうか。 9↑のように書いていた際に注意を受けたのですが、疑問を持ったので質問させて頂きました。 10 11ご回答よろしくお願い致します。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

蛇足ながら。
"注意を受けた"とのことですが、複数レコードの更新をAtomicにせよという仕様の問題ではありませんか?1回づつトランザクションをはるのと、複合処理を1トランザクションで行うのとではDoma2の機能以前にそもそもやってる内容が全く違う。
※問題無いなら無視してください。

投稿2017/06/30 08:01

kurokoba

総合スコア276

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

AppConfig.singleton().getTransactionManager() が、
org.seasar.doma.jdbc.tx.LocalTransactionManager だとした場合、
(org.seasar.doma.jdbc.tx.TransactionManagerの実体)
問題ないと思います。

Welcome to Doma
より、GitHub repositoryからソースをみました。

LocalTransactionManagerクラス

public void required(Runnable block) ↓ 呼び出し protected <RESULT> RESULT requiredInternal(TransactionIsolationLevel isolationLevel, Supplier<RESULT> supplier) ↓ 呼び出し protected <RESULT> RESULT executeInTransaction(TransactionIsolationLevel isolationLevel, Supplier<RESULT> supplier)

executeInTransaction()内でインスタンスのトランザクションに対して、
begin~commit~rollbackを行っているため、新たにトランザクションが作成されることはありません。

投稿2017/03/17 02:16

sugar_yas

総合スコア135

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

KNovata

2017/06/30 07:41

お礼が大変遅れてしまいました。 ご回答ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問