*

[C#]AS400に対してODBC接続でトランザクションによりSQLを実行する。

公開日: : AS400, C#, i Series, System i

データベースに対するトランザクション処理

と銘打ちましたが、要するに安全にinsert文などを実行するための処理です。

いつもTransactionの書き方を忘れて調べてるのでその備忘録。

ソース

using System.Data.Odbc;

public class Hoge{
	private const string Provider = "{iSeries Access ODBC Driver}";
	private const string Datasource = "192.168.0.2";
	private const string Username = "HOGE";
	private const string Password = "HOGE";

	public void Update(string[] sqls){
		using (var con = new OdbcConnection(GetConnectionString())) {
			con.Open();
			var transaction = con.BeginTransaction(System.Data.IsolationLevel.ReadCommitted);
			try {
				foreach (var sql in sqls) {
					using (var cmd = new OdbcCommand(sql, con, transaction)) {
						cmd.ExecuteNonQuery();
					}
				}
				transaction.Commit();
			} catch (OdbcException) {
				transaction.Rollback();
				throw;
			} finally {
				con.Close();
			}
		}
	}

	public static string GetConnectionString() {
	string[] conStrs = {
						   "Driver=" + Provider + ";", 
						   "System=" + Datasource + ";",
						   "Uid=" + Username + ";",
						   "Pwd=" + Password + ";",
					   };

		return string.Join("", conStrs);
	}
}

解説

Updateというメソッドに引数で実行したいSQL文字列の配列を渡して実行させます。
なお、SQLを投げる相手が上記のようにAS400(iSeries, System i, DB2)の場合はジャーナル処理をしているテーブルでないとSQL7008というエラーが出ますので注意です。
IsolationLevelは大抵の場合はReadCommitedで問題ないと思います。
並列処理などを行う際にのみ、ファントムリード(処理中のデータを読み取り、取得したデータが実際の値と違うものとなる)が出来てしまうのでお気をつけください。

ad

関連記事

socket p2p unity

[Unity]Socket通信でP2Pすっぞ ホストへ接続

前回はホストが待ちうけするところまで作りました。 今回はクライアントがホストへ接続できるように

記事を読む

logo

[C#]パスワード暗号化プログラムの初歩

パスワード暗号化の初歩的方法。 子供だましみたいなプログラムですね。 これは入社四か月の頃にプロ

記事を読む

unity rotate worldpoint

[Unity]コードリファレンス GameObjectを回転する。

くるくる回します。 rotationプロパティ Objectの向きをワールド座標で指定します

記事を読む

logo

[C#, AS400]列挙体の文字列化&DB2/400にODBC接続

定数をなるべく書きたくないんです。 あとからメンテをするときに複数箇所変更しなくてはいけないから。

記事を読む

logo

[Java, jt400]AS400のCLからJavaをCallする方法。

久しぶりにAS400ネタ。 CLからJavaを呼び出したい!! JavaをCLから実行したい

記事を読む

wannabenote

[jt400, java]AS400用のJavaをPCで実行したとき、終了しない理由

終了しない JavaでAS400をいじってると、たまに、終了しないんです。 プロセスが残ったまま

記事を読む

wannabenote_unity

[Unity]コードリファレンス ゲーム時間を表示する。

ゲーム内の時間を表示します。 Timeクラス 時間のためのクラスです。 ゲームが起動してか

記事を読む

Excel vsto 印刷設定 print setting

[C#, VSTO]Excelの印刷設定をする

印刷設定 VSTO(Visual Studio Tool for Office)Excelなんぞを

記事を読む

unity debug

[Unity]MonoDevelopのデバッグの仕方

コメントで頂いた質問を打破するためにデバッグの仕方でも書いてみます。 まずは、プロジェクトを開

記事を読む

logo

[iTextSharp,C#]TifファイルをPDFに変換する。

TifファイルをPDFに変換してほしいと言われて作ったときのソースのメイン部分を抜粋です。 確

記事を読む

ad

Comment

  1. Johne984 より:

    Hello to all, the contents existing at this site are in fact remarkable for people knowledge, well, keep up the nice work fellows. fedcegeabdeb

Johne984 にコメントする コメントをキャンセル

メールアドレスが公開されることはありません。

次のHTML タグと属性が使えます: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code class="" title="" data-url=""> <del datetime=""> <em> <i> <q cite=""> <strike> <strong> <pre class="" title="" data-url=""> <span class="" title="" data-url="">

ad

  •  Auther;わなび

     「オープン系得意だよね? 俺のPCの調子悪いんだけど」という無茶振りから解き放たれゲームエンジニアに。
    C#とかUnityを扱います。
    Twitterフォロー大歓迎です。
    githubアカウント→wannabenote
  • follow us in feedly
PAGE TOP ↑