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

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

19.12.2012, 15:41. Показов 899. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru