Форум программистов, компьютерный форум, киберфорум
Microsoft Access
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
9 / 9 / 0
Регистрация: 08.04.2012
Сообщений: 219

Запрос не корректно работает

19.12.2012, 15:41. Показов 873. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Нужно вывести всех учителей, у которых стаж работы находится в пределах. Если пределы выставляю изначально числом, то все работает. Например, так:
SQL
1
2
3
SELECT Учителя.[Номер школы], Учителя.Фамилия, Предметы.Предмет, Учителя.[Год поступления], YEAR(Now())-[Год поступления] AS Выражение1
FROM Предметы INNER JOIN Учителя ON Предметы.[Код предмета] = Учителя.[Код предмета]
WHERE (((YEAR(Now())-[Год поступления])>10 AND (YEAR(Now())-[Год поступления])<=15));
а если задаю ввод с клавиатуры, то ерунда какая-то(( что не правильно?

SQL
1
2
3
SELECT Учителя.[Номер школы], Учителя.Фамилия, Предметы.Предмет, Учителя.[Год поступления], YEAR(Now())-[Год поступления] AS Выражение1
FROM Предметы INNER JOIN Учителя ON Предметы.[Код предмета] = Учителя.[Код предмета]
WHERE (((YEAR(Now())-[Год поступления])>[Стаж от] AND (YEAR(Now())-[Год поступления])<=[стаж до]));
причем, если поменять знаки и попросить найти людей, чей стаж НЕ входит в эти рамки, то прекрасно всё выводит
SQL
1
2
3
SELECT Учителя.[Номер школы], Учителя.Фамилия, Предметы.Предмет, Учителя.[Год поступления], YEAR(Now())-[Год поступления] AS Выражение1
FROM Предметы INNER JOIN Учителя ON Предметы.[Код предмета] = Учителя.[Код предмета]
WHERE (((YEAR(Now())-[Год поступления])<[Стаж от] AND (YEAR(Now())-[Год поступления])>=[стаж до]));
Вложения
Тип файла: rar учителя.rar (43.0 Кб, 6 просмотров)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
19.12.2012, 15:41
Ответы с готовыми решениями:

Запрос работает не корректно
Создал запрос, всё вроде как надо сделал. Мне надо чтобы пользователь вводил в запрос дату и(или) место и(или) название, а программа...

Запрос не корректно считает
Бьюсь с запросом вычисляющим остатки. Разницей полей в таблицах ЗаказанныеТовары и Поступившие товары. Но считает некорректно. Не могу...

Запрос не всегда корректно работает. Как исправить?
Есть такие, упрощённо, таблицы: CREATE TABLE dbo.DataTable ( CityId uniqueidentifier NOT NULL, CompanyId uniqueidentifier NOT...

4
3544 / 1118 / 94
Регистрация: 13.03.2011
Сообщений: 1,513
19.12.2012, 16:20
Вы, очевидно перепутали.
Запрос
SQL
1
2
3
SELECT Учителя.[Номер школы], Учителя.Фамилия, Предметы.Предмет, Учителя.[Год поступления], YEAR(Now())-[Год поступления] AS Выражение1
FROM Предметы INNER JOIN Учителя ON Предметы.[Код предмета] = Учителя.[Код предмета]
WHERE (((YEAR(Now())-[Год поступления])>[Стаж от] AND (YEAR(Now())-[Год поступления])<=[стаж до]));
прекрасно работает (задавал [Стаж от]=10 и [стаж до]=15).
А вот запрос, в котором нужно найти людей, чей стаж НЕ входит в эти рамки, для чего вы поменяли знаки неравенств предыдущего запроса
SQL
1
2
3
SELECT Учителя.[Номер школы], Учителя.Фамилия, Предметы.Предмет, Учителя.[Год поступления], YEAR(Now())-[Год поступления] AS Выражение1
FROM Предметы INNER JOIN Учителя ON Предметы.[Код предмета] = Учителя.[Код предмета]
WHERE (((YEAR(Now())-[Год поступления])<[Стаж от] AND (YEAR(Now())-[Год поступления])>=[стаж до]));
никаких результатов не выводит, потому что, как учит алгебра логики, мало поменять знаки отношений (причем вы их поменяли неверно), но нужно еще поменять и логическую операцию.
Ваше условие должно звучать так
SQL
1
... WHERE (((YEAR(Now())-[Год поступления])<=[Стаж от] OR (YEAR(Now())-[Год поступления])>[стаж до]))
Проверил при тех же значениях параметров, заработало.
0
9 / 9 / 0
Регистрация: 08.04.2012
Сообщений: 219
19.12.2012, 17:10  [ТС]
minob, умом-то я тоже понимаю всё то, что Вы написали. но по факту вот такая ерунда:

при запросе с числом 5
SQL
1
2
3
SELECT Учителя.[Номер школы], Учителя.Фамилия, Предметы.Предмет, Учителя.Год_поступления, (YEAR(Now())-[Год_поступления]) AS Выражение1
FROM Предметы INNER JOIN Учителя ON Предметы.[Код предмета] = Учителя.Код_предмета
WHERE ((((YEAR(Now())-[Год_поступления]))>5));
картинка №1


при запросе
SQL
1
2
3
SELECT Учителя.[Номер школы], Учителя.Фамилия, Предметы.Предмет, Учителя.Год_поступления, (YEAR(Now())-[Год_поступления]) AS Выражение1
FROM Предметы INNER JOIN Учителя ON Предметы.[Код предмета] = Учителя.Код_предмета
WHERE ((((YEAR(Now())-[Год_поступления]))>[стаж от]));
картинка №2


вот как так??? ведь суть-то одна и та же!
0
3544 / 1118 / 94
Регистрация: 13.03.2011
Сообщений: 1,513
19.12.2012, 17:46
Цитата Сообщение от Shelty Посмотреть сообщение
вот как так??? ведь суть-то одна и та же!
Причина непоняток в том, что параметры [стаж от] и [стаж до] не описаны и поэтому по умолчанию они будут иметь строковый тип, и при сравнении операнды сравниваются как строки, например, "12" < "5". Чтобы исправить ситуацию объявите параметр(ы) явно, например, для последнего запроса первой строкой пропишите
SQL
1
PARAMETERS [стаж от] Long;
Для запросов из первого поста
SQL
1
PARAMETERS [стаж от] Long, [стаж до] Long;
1
9 / 9 / 0
Регистрация: 08.04.2012
Сообщений: 219
19.12.2012, 17:50  [ТС]
да! спасибо Вам!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.12.2012, 17:50
Помогаю со студенческими работами здесь

Запрос не корректно выводит данные
Запрос не корректно выводит данные, например если я задал что бы в колонке id_u_succ выводило только строки NULL, то даже если она не NULL...

Как корректно составить запрос?
Добрый день, сижу уже больше часа и не могу понять как именно составить запрос. Есть 2 таблицы: ContactRes и ContactCamp. Они джойнятся...

Выполнить корректно запрос Oracle sql
Есть БД к которой кое как подключился ибо слетел срок регистрации учетки, до этого разве что делал только дампы. Нужно выполнить...

Запрос работает не корректно
Здравствуйте! У меня запрос не корректно работает, работает отдельно: :wall: (table3.NAMEagent&lt;&gt;table3.nameperson and ...

Sql запрос не корректно работает
SELECT DISTINCT ПодКатегория_Данные.Наименование FROM ПодКатегория_Данные Where Адрес LIKE &quot;*Горького*&quot; Первый запрос в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru