|
Сервер содержит море(!) аналитической информации
|
CIT Forum CD-ROM
|
|
2.3.2. Использование BETWEEN
С помощью BETWEEN ... AND ... (находится в интервале от ... до ...) можно отобрать строки, в которых значение какого-либо столбца находятся в заданном диапазоне.
Например, выдать перечень продуктов, в которых значение содержания белка находится в диапазоне от 10 до 50:
| Результат: |
|---|
SELECT Продукт, Белки
FROM Продукты
WHERE Белки BETWEEN 10 AND 50; |
| Продукт | Белки |
| Майонез | 31. |
| Сметана | 26. |
| Молоко | 28. |
| Морковь | 13. |
| Лук | 17. |
Можно задать и NOT BETWEEN (не принадлежит диапазону между), например:
| Результат: |
|---|
SELECT Продукт, Белки, Жиры
FROM Продукты
WHERE Белки NOT BETWEEN 10 AND 50
AND Жиры > 100; |
| Продукт | Белки | Жиры |
| Говядина | 189. | 124. |
| Масло | 60. | 825. |
| Яйца | 127. | 115. |
BETWEEN особенно удобен при работе с данными, задаваемыми интервалами, начало и конец которых расположен в разных столбцах.
Для примера воспользуемся таблицей "минимальных окладов" (табл. 2.1), величина которых непосредственно связана со студенческой стипендией. В этой таблице для текущего значения минимального оклада установлена запредельная дата окончания 9 сентября 9999 года.
Таблица 2.1
Минимальные оклады
| Миноклад | Начало | Конец |
| 2250 | 01-01-1993 | 31-03-1993 |
| 4275 | 01-04-1993 | 30-06-1993 |
| 7740 | 01-07-1993 | 30-11-1993 |
| 14620 | 01-12-1993 | 30-06-1994 |
| 20500 | 01-07-1994 | 09-09-9999 |
Если, например, потребовалось узнать, какие изменения минимальных окладов производились в 1993/94 учебном году, то можно выдать запрос
SELECT Начало, Миноклад
FROM Миноклады
WHERE Начало BETWEEN '1-9-1993' AND '31-8-1994'
и получить результат:
| Начало | Миноклад |
| 01-12-1993 | 14620 |
| 01-07-1994 | 20500 |
Отметим, что при формировании запросов значения дат следует заключать в апострофы, чтобы СУБД не путала их с выражениями и не пыталась вычитать из 31 значение 8, а затем 1994.
Для выявления всех значений минимальных окладов, которые существовали в 1993/94 учебном году, можно сформировать запрос
SELECT *
FROM Миноклады
WHERE Начало BETWEEN '1-9-1993' AND '31-8-1994'
OR Конец BETWEEN '1-9-1993' AND '31-8-1994'
| Миноклад | Начало | Конец |
| 7740 | 01/07/1993 | 30/11/1993 |
| 14620 | 01/12/1993 | 30/06/1994 |
| 20500 | 01/07/1994 | 09/09/9999 |
Наконец, для получения минимального оклада на 15-5-1994:
| Результат: |
|---|
SELECT Миноклад
FROM Миноклады
WHERE '15-05-1994' BETWEEN Начало AND Конец |
| Миноклад |
|---|
| 14620 |
2.3.1 | Содержание | 2.3.3