質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Q&A

解決済

2回答

1287閲覧

Nullが許容されている列をWhereで検索したい

syott

総合スコア2

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

0グッド

0クリップ

投稿2020/08/18 11:29

編集2020/08/18 12:51

前提・実現したいこと

初めて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で条件分岐して検索してみたいです。

うまく質問の意図を伝えられず申し訳ございません。

なにか良い方法があればご教授お願いしたいです。よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Zuishin

2020/08/18 12:11

> C#のプログラムの方で条件分岐してSQLを変えればいいとは思うのですが、SQLで条件分岐して検索してみたいです。 タグを変えてください。これは C# の質問ではなく、SQL の質問です。C# が不得手で SQL が得意な回答者を切り捨てています。
guest

回答2

0

ベストアンサー

ちょっと自信ない。動作確認できてないけど

SQL

1AND Memo Like ISNULL(@strMemo, Memo)

の部分を

SQL

1AND (Memo Like ISNULL(@strMemo, Memo) OR ISNULL(@strMemo, Memo) IS NULL)

と、したらどうでしょうか。

投稿2020/08/18 18:26

編集2020/08/18 18:33
momon-ga

総合スコア4820

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

syott

2020/08/19 00:29

回答ありがとうございます! momon-ga さんに記載していただいたSQLで動作確認を行ったところ、 自分の期待する結果が出力されました!ありがとうございます! ISNULLでチェックした後の結果に IS NULLを使う発想は思いつきませんでした・・@@ 夜分遅くにご回答いただき、改めてありがとうございます。
guest

0

回答をいただきましたが、もっと簡単に検索できることを教えていただきましたので共有します。

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) OR ISNULL(@strMemo, Memo) IS NULL) 11

SQL

1Declare @strMemo nvarchar(20) 2Declare @id int 3 4SET @strMemo = null(もしくは入力された文字列) 5SET @id = null(もしくは入力された値) 6 7SELECT ID, Memo 8FROM テーブル 9WHERE (@id IS NULL OR ID = @id) 10AND (@strMemo IS NULL OR Memo LIKE @strMemo)

WHERE カラム = カラム で検索を飛ばそうとしていましたが、
(@id IS NULL OR ID = @id)とすることで、@idがNULLならそもそも検索をしないというSQLにできるみたいです

投稿2020/08/19 04:11

syott

総合スコア2

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問