Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
3 / 2 / 2
Регистрация: 21.03.2017
Сообщений: 297

Запрос не всегда корректно работает. Как исправить?

24.01.2020, 08:24. Показов 1121. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть такие, упрощённо, таблицы:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
CREATE TABLE dbo.DataTable
    (
    CityId uniqueidentifier NOT NULL,
    CompanyId uniqueidentifier NOT NULL,
    ChangedOn datetime NOT NULL,
    ParamType uniqueidentifier NOT NULL,
    ParamLastValue uniqueidentifier NULL,
    ParamNewValue uniqueidentifier NULL
    )  ON [PRIMARY]
GO
 
CREATE TABLE dbo.FilterTable
    (
    CityId uniqueidentifier NOT NULL,
    Param1 uniqueidentifier NULL,
    Param2 uniqueidentifier NULL,
    Param3 uniqueidentifier NULL
    )  ON [PRIMARY]
GO
Первая таблица хранит историю переходов различных параметров компании из одного состояния в другое. Вторая - фильтр. Задача: выбрать из таблицы компании, которые удовлетворяют фильтру. Т.е. должны выбраться компании, которые имеют самые новые состояния, соответствующие фильтру. Попытался сделать это, примерно, так:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
SELECT TOP 1 WITH TIES
    CompanyId
FROM DataTable dt 
    INNER JOIN FilterTable ft ON ft.CityId = dt.CityId
    INNER JOIN DataTable dt1 ON dt1.CityId = dt.CityId AND dt1.ParamType = Type1
    INNER JOIN DataTable dt2 ON dt2.CityId = dt.CityId AND dt1.ParamType = Type2
    INNER JOIN DataTable dt3 ON dt3.CityId = dt.CityId AND dt1.ParamType = Type3
WHERE
    dt1.ParamNewValue = ft.Param1
    AND dt2.ParamNewValue = ft.Param2
    AND dt3.ParamNewValue = ft.Param3
ORDER BY ROW_NUMBER() OVER(PARTITION CompanyId, dt1.ParamType, dt2.ParamType, dt3.ParamType 
                           ORDER BY dt1.ChangedOn DESC, dt2.ChangedOn DESC, dt3.ChangedOn DESC)
Но запрос не все верные результаты возвращает - для некоторых компаний вместо нового значения возвращается предыдущее. В чём может быть дело? Что не так делаю?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.01.2020, 08:24
Ответы с готовыми решениями:

Сортировка слиянием. Моя релизация не всегда корректно работает
Здравствуйте. Помогите найти ошибку, уже который день бьюсь над вопросом. 2- и 3-размерные массивы сортирует, а 4-элементные уже нет. Вот...

Определение количества страниц документа не всегда работает корректно
Всем здравствуйте! Для определения количества страниц активного документа Word, использовал такой код: Sub DetectNumPages() Dim...

Условие макроса сравнение дат и времени работает не корректно.Как это исправить?
Sub Макрос_1() For i = 5 To Sheets("Ввод Данных").Range("A" & Rows.Count).End(xlUp).Row If Sheets("Ввод...

3
5966 / 4542 / 1094
Регистрация: 29.08.2013
Сообщений: 28,151
Записей в блоге: 3
24.01.2020, 08:30
ну так выведи ту строку где правильно и ту где неправильно и посмотри чем они отличаются (неправильная сортировка?)
0
3 / 2 / 2
Регистрация: 21.03.2017
Сообщений: 297
24.01.2020, 09:05  [ТС]
Это я первым делом сделал - никаких отличий не увидел.
0
3 / 2 / 2
Регистрация: 21.03.2017
Сообщений: 297
11.02.2020, 07:01  [ТС]
Решил проблему.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.02.2020, 07:01
Помогаю со студенческими работами здесь

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

Запрос не корректно работает
Здравствуйте! Нужно вывести всех учителей, у которых стаж работы находится в пределах. Если пределы выставляю изначально числом, то все...

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

Исправить ошибку в коде (Программа не корректно работает с ру языком)
всем привет программа работает на eng языке а вот на Русском проблемы она оставляет одну букву хотя должа захватывать её для переноса в...

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


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru