SQLクエリ文字列は,埋め込みリソース化するテキストファイルを利用すると,より便利です
関連記事
- 【#CSharp】C#が2025年「プログラミング言語オブ・ザ・イヤー」獲得 【2026年01月16日(金)】
- なんと!今週の土曜日も仕事してますた.来週の土曜日も仕事臭い.TCPソケット通信をゴリゴリ書いてる 【2025年08月30日(土)】
- 【ChatGPT o4】祝日なのに仕事ーバテすぎー今夜こそ絶命だーモルモルモル 【2025年03月20日(木)】
- 【#CSharp】制御系が動き出したべ 【2025年02月20日(木)】
- 【#CSharp】ひっさしぶりにガッツリなC#案件をやっているぞー 【2025年02月19日(水)】
「SQLクエリ文字列は,文字列リソースファイルに記述したら便利です」
って,昔は,文字列リソースファイルに記述しておったんじゃけど
これ,SQLクエリが縦に長くなってくると,非常に見づらい(汗
Visual Studioのリソースエディタの縦スクロールの処理がイマイチで,巨大クエリの一部が,キレイに表示されないわ
カーソル移動によっては,次の文字列リソース位置に,フォカースが移るわ,で
オイラ平気で,数段ネストのある副クエリを書きまくるので
SQLがバグると,非常にデバッグがめんどくさい
ってことで,最近は,SQLをテキストファイルに記述して
このテキストファイルを,VSのプロジェクトに引き込み,EXE内へ埋め込みリソースとして組み込む,みたいなやり方が増えてきておりまする
(ソリューションエクスプローラから,テキストファイルを選択して,プロパティ:ビルドアクションを「埋め込まれたリソース」に変更するだけで,EXEに組み込まれまする)
埋め込みリソーステキストファイルなら,VSのエディタでも,普通のソースファイルとして表示編集できますし(縦方向に長くなってもイライラしなくて済むしのぉ)
C#辺りからアクセスするには
//---------------------------------------------
//リソースからクエリ文字列を取得
//
//---------------------------------------------
protected string LoadQueryText(string path)
{
//現在のコードを実行しているAssemblyを取得
System.Reflection.Assembly myAssembly =
System.Reflection.Assembly.GetExecutingAssembly();
System.IO.Stream stm = myAssembly.GetManifestResourceStream(path);
//指定されたマニフェストリソースを読み込む
System.IO.StreamReader sr =
new System.IO.StreamReader(
stm,
System.Text.Encoding.GetEncoding("shift-jis")
);
//内容を読み込む
string s = sr.ReadToEnd();
//後始末
sr.Close();
return s;
}
......
string sql;
sql = LoadQueryText("DBCtrl.Query2.tbl.S." + "sql_s_selectlistall.txt");
にて.DBCtrlがアセンブリ名
Query2.tbl.S.は,ファイルが置かれているプロジェクト内フォルダ名
sql_s_selectlistall.txtが,SQLクエリが書かれている,テキストファイル本体でごわす

コメント
【#花粉症】目が腫れてキターくしゃみも止まらん.いよいよ花粉もピークか?
【#衆議院選挙2026 】自民 316議席獲得 単独で3分の2超 中道は49議席
【#衆議院選挙2026 】自民単独で過半数大きく上回り300議席に達する可能性
【BW55T】UPSが死んだ...ドロドロドロ😭これは人類滅亡間違いなし!なので発注(爆
広島カープの羽月隆太郎容疑者、「ゾンビたばこ」使用の疑いで逮捕
【#総選挙】衆議院選挙 きょう公示 12日間の選挙戦へ
青森 スノーモービル乗るため入山の約10人と連絡取れず 遭難か
【#不発弾】宮崎市中心部の不発弾 17日に処理 避難指示や交通規制予定(26/1/17)