SQLクエリ文字列は,埋め込みリソース化するテキストファイルを利用すると,より便利です
関連記事
- 【#CSHARP】ソリューション内でサービス,Winformアプリを混在で作成させ,バイナリ出力先を同じにするとサービスが起動しない 【2024年02月08日(木)】
- 【#PHP】謎な #Laravel 案件 引き渡したじ 【2024年01月11日(木)】
- 【C#】謎な改造アプリ,SIMD命令を導入して高速化しようか,思案中 【2023年11月14日(火)】
- Javaの”やらかし”でC#と人気逆転か 激変プログラミング言語人気ランキング 【2023年10月18日(水)】
- 【#CSHARP】次の案件のスケルトン書いてgitサーバに登録するなどと 【2023年05月16日(火)】
「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クエリが書かれている,テキストファイル本体でごわす
コメント
九州自動車道 トンネル内で大型トレーラーから出火 人吉~八代間で通行止め(24/7/26)
【#ご到着シリーズ】冷凍かしわ飯&冷凍かしわうどんセットに当選したモルモルモル
【#破局噴火】イエローストーンで大規模な水蒸気爆発が発生
暑すぎてダレてる.なんのやる気も起こらんドロドロドロ
【#Windows #CrowdStrike】セキュリティーソフト世界シェア1位があだ…ウィンドウズ障害、「過去最大規模」の見方も
3連休,らしい.これといって予定はない(爆
【#trump #shooting】トランプ暗殺未遂:トランプ氏 集会で発砲音「前大統領は無事」死者も
【#線状降水帯】九州北部山口県に線状降水帯発生予測情報発令(24/7/13)
【#落雷】今朝の雷,すごかったー 清武城かお隣のマンションに落雷したー共用部の電源落ちてるテレビが映らない!
【#彗星】紫金山アトラス彗星(C/2023 A3)がぶっ壊れた!今秋,見れると思ってたのにピエン