前提・実現したいこと
初めてteratailを利用させていただきます。質問の仕方が拙い部分が多くあるかと思われますが、ご了承ください。
現在、VisualStudioでWindowsフォームからSqlServerに接続し、データベースをDataGridViewに表示する、といったプログラムを作っています。
検索したい値、文字列を入力するテキストボックスがあり、検索ボタンを押すことで、テキストボックスの内容をもとにデータベースに検索をかけて抽出したいと考えております。また、この際、テキストボックスに何も入力されていない場合は、何も検索しないようにもしたいと考えております。
↓現在自分が書いているコードをかいつまんだもの↓
C#
1 2 3string constr = "SQLServerの接続文字列" 4 5using(var connect = new SqlConnection(constr) 6{ 7 connection.Open(); 8 9 string searchID; 10 if(TextBox1.Text == "") 11 { 12 searchID = "null"; 13 } 14 else 15 { 16 searchID = "¥'" + TextBox1.Text + "¥'"; 17 } 18 19 string searchMemo; 20 if(TextBox2.Text == "") 21 { 22 searchMemo = "null"; 23 } 24 else 25 { 26 searchMemo = "¥'" + TextBox2.Text + "¥'"; 27 } 28 29 string sqlstr = 30 "Declare @strMemo nvarchar(20) " + 31 "Declare @id int " + 32 $"SET @strMemo = {searchMemo} " + 33 $"SET @id == {searchID} " + 34 "SELECT ID, Memo FROM テーブル " + 35 "WHERE ID = ISNULL(@id, ID) " + 36 "AND Memo Like ISNULL(@strMemo, Memo)"; 37 38 using(var command = new SqlCommand(sqlstr,connection) 39 { 40 using(var reader = command.ExecuteReader()) 41 { 42 DataTable dbTable = new DataTable(); 43 dbTable.Load(reader) 44 45 DataGridView.DataSource = dbTable 46 } 47 } 48} 49 50 51
テーブル
ID Memo(nullが許容されている) -------------- 1 NULL 2 NULL 3 hoge 4 NULL
SQL
1Declare @strMemo nvarchar(20) 2Declare @id int 3 4SET @strMemo = null(もしくは入力された文字列) 5SET @id = null(もしくは入力された値) 6 7SELECT ID, Memo 8FROM テーブル 9WHERE ID = ISNULL(@id, ID) 10AND Memo Like ISNULL(@strMemo, Memo)
Where ID = ID
AND Memo Like Memo
という検索になると結果は
ID Memo -------------- 3 hoge
と、NULLのレコードが抽出されません。
Where Memo Like Memo or Memo IS NULL ならば
NULLのレコードも抽出されるので、ISNULL(@strMemo, Memo OR Memo IS NULL)のように書いてはみましたが構文エラーです。
C#のプログラムの方で条件分岐してSQLを変えればいいとは思うのですが、SQLで条件分岐して検索してみたいです。
うまく質問の意図を伝えられず申し訳ございません。
なにか良い方法があればご教授お願いしたいです。よろしくお願いします。

回答2件
あなたの回答
tips
プレビュー