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

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

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

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

SQL

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

Q&A

解決済

2回答

146閲覧

SQLの範囲検索についてご教示ください

yuuya0626

総合スコア13

SQL Server

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

SQL

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

0グッド

0クリップ

投稿2017/07/05 02:49

テーブルAの開始No・終了Noが検索条件のFromTOの範囲内のレコードを取得する方法をご教示ください。

例)
<検索条件>
From:4
To:13

<テーブルA>
開始No|終了No
1 |2 取得できない
3 |6 取得できる
7 |13 取得できる
14 |15 取得できない

よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

検索条件の区間の内部に含まれる場合

SQL

1ELECT * FROM Tbl 2WHERE 3 "TO" <= 開始No And 終了No <= "FROM";

検索条件の区間に一部でも重なる場合

SQL

1SELECT * FROM Tbl 2WHERE 3 開始No <= "TO" And "FROM" <= 終了No;

一番シンプルに記述する例です。
なぜそうなるかは、下図とにらめっこして考えてください。
下記の図の「抽出期間」は「抽出区間」と読み替えてください。

イメージ説明

参考URL
クエリでの期間の抽出条件 - hatena chips

投稿2017/07/05 03:35

hatena19

総合スコア33715

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

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

yuuya0626

2017/07/05 03:50

回答ありがとうございます。 回答に気づく前に早まってBAしてしまいました。 「検索条件の区間に一部でも重なる場合」の方法で意図したとおり取得することができました。
guest

0

ベストアンサー

開始NOが3なのになぜFrom:4の条件に合致するのでしょうか?
一部でも引っかかればいいということでしょうか?
そうなるとこんなかんじで

Fromデータ BETWEEN 開始NO AND 終了No OR TOデータ BETWEEN 開始NO AND 終了No

FROMのように予約語を例示につかうのはやめたほうがいいでしょう

投稿2017/07/05 03:09

yambejp

総合スコア114839

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

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

yuuya0626

2017/07/05 03:19

回答ありがとうございます。 一部でも引っかかればいいということです。
yuuya0626

2017/07/05 03:41

すみません。 これだと例えばTOデータを16にした場合に開始No:7 終了No:13のデータが取得できなくなってしまいます。本来7~13は4~16の範囲に収まっているので取得できます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問