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

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

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

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

1回答

722閲覧

[SQL Server]引数によってWHERE句のLIKEとNOT LIKEを切り替える

woria

総合スコア36

SQL Server

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

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2021/03/22 07:32

編集2021/03/22 07:46

前提・実現したいこと

BITを引数とするストアドプロシージャを作成します。
BITによって、WHERE句に記入した検索条件を反転させたいです。

該当のソースコード

以下のNAME列を持つテーブルに対し

SQL

1CREATE TABLE #TEMP( 2NAME VARCHAR(10) 3) 4 5INSERT #TEMP VALUES('Sato 1') 6INSERT #TEMP VALUES('Sato 2') 7INSERT #TEMP VALUES('Tanaka 1') 8INSERT #TEMP VALUES('Tanaka 2') 9INSERT #TEMP VALUES('Sasaki 1')

引数がTrueの場合

SQL

1SELECT * FROM #TEMP WHERE #TEMP.NAME LIKE 'Sato%'

引数がFalseの場合

SQL

1SELECT * FROM #TEMP WHERE #TEMP.NAME NOT LIKE 'Sato%'

を切り替えたいです。

試したこと

SQL

1DECLARE @IS_SATO BIT = 1 2 3CREATE TABLE #TEMP( 4NAME VARCHAR(10) 5) 6 7INSERT #TEMP VALUES('Sato 1') 8INSERT #TEMP VALUES('Sato 2') 9INSERT #TEMP VALUES('Tanaka 1') 10INSERT #TEMP VALUES('Tanaka 2') 11 12SELECT * FROM #TEMP 13WHERE 14IF @IS_SATO = 1 15 #TEMP.NAME LIKE 'Sato%' 16ELSE 17 #TEMP.NAME NOT LIKE 'Sato%' 18END 19DROP TABLE #TEMP

補足情報(FW/ツールのバージョンなど)

Microsoft SQL Server Management Studio v18.5

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

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

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

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

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

sazi

2021/03/22 07:38 編集

引数をifで判定すれば良いだけでは? bit判定が不明という事なら、ストアードの定義(引数含めた外観のみ)を追記して下さい
guest

回答1

0

ベストアンサー

SQLをif文で区切ってしまうとエラーになります。

SQL

1IF @IS_SATO = 1 2 SELECT * FROM #TEMP WHERE #TEMP.NAME LIKE 'Sato%'; 3ELSE 4 SELECT * FROM #TEMP WHERE #TEMP.NAME NOT LIKE 'Sato%';

投稿2021/03/22 07:57

sazi

総合スコア25206

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問