*

[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

関連記事

addcomp

[Unity]コードリファレンス コンポーネントをアタッチする。

コンポーネントをプログラム実行時に追加します。 AddComponent() AddComp

記事を読む

wannabenote

[C#, Excel]最終行を取得する

Excelを触っているのでC#でExcelネタが続きます。 Excelの行数が知りたい Exce

記事を読む

logo

[C#]AS400をDBに見立ててPCのPGMからODBC接続する

◆前提条件◆ PCにClient Accessがインストールされている。 PCに.NET Fra

記事を読む

Excel Csharp

[C#]DataGridViewにプロパティを利用しながら配列をバインドする。

DataGridView C#のFormにデータを表示するのに便利なコントロールがあります。 デ

記事を読む

PDFClearBlankToText

[C#, iTextsharp]PDFClearBlankToText PDFのテキストを読み込んで空白削除する

使用は自己責任でお願いします。 ◆概要 前回のBlankClearのあとにPDFからコピペが

記事を読む

Unity_

[Unity]Unity 2Dチュートリアル スプライトを元の位置に戻す

前回ドラッグして移動するところまでは作成したのですが、パズドラって、タップしてもその場から動かさなか

記事を読む

logo

プログラミング言語の選択

最初のプログラミング言語っていうのは思い入れが深いもんです。 私はこんな感じ。 C言語 ↓ jav

記事を読む

logo

[C#]AS400のメンバーを指定してデータにアクセスする

◆前提条件◆ CliantAccessをインストールしている。 .NET Framework3.

記事を読む

socket p2p unity

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

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

記事を読む

logo

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

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

記事を読む

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

Message

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

次の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 ↑