Получить отдельные строки в запросе

У меня есть запрос SQL-сервера для извлечения данных из SQL Server в фрейм данных Python, как показано ниже. Мне нужно сохранить только уникальные строки на основе двух столбцов дата и прилавок

SELECT 
    CAST([A2_TIRE_A_CO_D300_TIMESTAMP] AS DATE) AS date,
    [A2_TIRE_A_CO_D362_VALUE] AS counter,
    [A2_TIRE_A_CO_D400_VALUE] AS D400,
    [A2_TIRE_A_CO_D402_VALUE] AS D402,
    [A2_TIRE_A_CO_D412_VALUE] AS D412,
    [A2_TIRE_A_CO_D414_VALUE] AS D414,
    [A2_TIRE_A_CO_D416_VALUE] AS D416,
    [A2_TIRE_A_CO_D420_VALUE] AS D420,
    [A2_TIRE_A_CO_D422_VALUE] AS D422,
    [A2_TIRE_A_CO_D432_VALUE] AS D432
FROM 
    [aaaa2_tttt_a].[dbo].[tttt_a] 
WHERE
    [A2_TIRE_A_CO_D300_TIMESTAMP] >= DATEADD(Hour, -1, GETDATE()) 
    AND [A2_TIRE_A_CO_L102_VALUE] = 1 
    AND [A2_TIRE_A_CO_L100_VALUE] = 1
| date       | counter | D400        | D402                         | D412        |
|------------|---------|-------------|------------------------------|-------------|
| 2022-04-23 | 2434    | 12848 14393 | 20808 8257 12339 13360 12601 | 16705 16948 |
| 2022-04-23 | 2434    | 12848 14393 | 20808 8257 12339 13360 12601 | 16705 16948 |
| 2022-04-23 | 2434    | 12848 14393 | 20808 8257 12339 13360 12601 | 16705 16948 |
| 2022-04-23 | 2435    | 12848 14393 | 20808 8257 12339 13360 12601 | 16705 16948 |
| 2022-04-23 | 2435    | 12848 14393 | 20808 8257 12339 13360 12601 | 16705 16948 |
| 2022-04-23 | 2435    | 12848 14393 | 20808 8257 12339 13360 12601 | 16705 16948 |
| 2022-04-23 | 2435    | 12848 14393 | 20808 8257 12339 13360 12601 | 16705 16948 |

Требование

| date       | counter | D400        | D402                         | D412        |
|------------|---------|-------------|------------------------------|-------------|
| 2022-04-23 | 2434    | 12848 14393 | 20808 8257 12339 13360 12601 | 16705 16948 |
| 2022-04-23 | 2435    | 12848 14393 | 20808 8257 12339 13360 12601 | 16705 16948 |

Я пробовал другой метод и другие источники. Как мне это сделать?

Я попытался создать новый столбец, объединив дату и счетчик и применив разные:

DISTINCT(CONCAT(CAST([A2_TIRE_A_CO_D300_TIMESTAMP] AS DATE),[A2_TIRE_A_CO_D362_VALUE]) AS unique_column)

но я думаю, что это не правильный путь

Я попытался создать новый столбец, объединив дату и счетчик и применив отличные: отличные (concat (CAST ([A2_TIRE_A_CO_D300_TIMESTAMP] AS DATE), [A2_TIRE_A_CO_D362_VALUE]) как unique_column). но я думаю, что это не правильный путь. нет необходимости создавать новый столбец.

user_v27 23.04.2022 07:13

отредактировано в вопросе

user_v27 23.04.2022 07:18

Я думаю, что в этом вопросе они просят верхнюю строку на основе одного столбца. Мой вопрос: мне нужны строки на основе двух столбцов

user_v27 23.04.2022 07:19

Тот же принцип, вы просто адаптируете row_number к своим потребностям.

Dale K 23.04.2022 07:26
3 метода стилизации элементов HTML
3 метода стилизации элементов HTML
Когда дело доходит до применения какого-либо стиля к нашему HTML, существует три подхода: встроенный, внутренний и внешний. Предпочтительным обычно...
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
0
4
37
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы можете попробовать использовать оконную функцию ORDER BY и ROW_NUMBER.

partition by может потребоваться указать, какой столбец вы хотите представлять unique строку.

SELECT TOP 1 WITH 
    CAST([A2_TIRE_A_CO_D300_TIMESTAMP] AS DATE) as date,
    [A2_TIRE_A_CO_D362_VALUE] as counter,
    [A2_TIRE_A_CO_D400_VALUE] as D400,
    [A2_TIRE_A_CO_D402_VALUE] as D402,
    [A2_TIRE_A_CO_D412_VALUE] as D412,
    [A2_TIRE_A_CO_D414_VALUE] as D414,
    [A2_TIRE_A_CO_D416_VALUE] as D416,
    [A2_TIRE_A_CO_D420_VALUE] as D420,
    [A2_TIRE_A_CO_D422_VALUE] as D422,
    [A2_TIRE_A_CO_D432_VALUE] as D432
FROM [aaaa2_tttt_a].[dbo].[tttt_a] 
where 
    [A2_TIRE_A_CO_D300_TIMESTAMP] >= DATEADD(Hour,  -1,  GETDATE()) 
and 
    [A2_TIRE_A_CO_L102_VALUE] =1 
and 
    [A2_TIRE_A_CO_L100_VALUE] =1
order by row_number() over (partition by CAST([A2_TIRE_A_CO_D300_TIMESTAMP] AS DATE),[A2_TIRE_A_CO_D362_VALUE] order by date)

но я думаю, что вы можете использовать DISTINCT непосредственно из ваших образцов данных и ожидать результата.

SELECT DISTINCT CAST([A2_TIRE_A_CO_D300_TIMESTAMP] AS DATE) as date,
    [A2_TIRE_A_CO_D362_VALUE] as counter,
    [A2_TIRE_A_CO_D400_VALUE] as D400,
    [A2_TIRE_A_CO_D402_VALUE] as D402,
    [A2_TIRE_A_CO_D412_VALUE] as D412,
    [A2_TIRE_A_CO_D414_VALUE] as D414,
    [A2_TIRE_A_CO_D416_VALUE] as D416,
    [A2_TIRE_A_CO_D420_VALUE] as D420,
    [A2_TIRE_A_CO_D422_VALUE] as D422,
    [A2_TIRE_A_CO_D432_VALUE] as D432
FROM [aaaa2_tttt_a].[dbo].[tttt_a] 
where 
    [A2_TIRE_A_CO_D300_TIMESTAMP] >= DATEADD(Hour,  -1,  GETDATE()) 
and 
    [A2_TIRE_A_CO_L102_VALUE] =1 
and 
    [A2_TIRE_A_CO_L100_VALUE] =1

2-я работа. 1-й выдает ошибку. Спасибо!

user_v27 23.04.2022 07:26

Это такой распространенный вопрос, который вы должны закрывать как дубликат, а не отвечать.

Dale K 23.04.2022 07:27

Другие вопросы по теме