SQL-сервер: хранимая процедура

У меня есть таблица с 6 столбцами (id, deviceID, athleteName, fieldName, valueTx, dateTime).

Пока что, когда я вызываю свою функцию getSensors, она отображает все строки.

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

Я никогда не использовал процедуру хранения, поэтому мне интересно, что лучше всего? Если нет, что вы предлагаете мне делать?

Спасибо заранее!!!

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
28
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

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

Для этого вам не нужна хранимая процедура. Простой запрос:

select t.*
from t
where t.datetime = (select max(t2.datetime) from t t2 where t2.deviceID = t.deviceID);

Если вам дан deviceID, вы можете получить самую последнюю запись как:

select t.*
from t
where t.deviceID = v_deviceID
order by t.datetime desc
limit 1;

Ой, извините, я не это имел в виду. У меня есть несколько строк deviceID, и у некоторых из них одинаковый deviceID. Я хочу отображать 1 строку для каждого идентификатора устройства, самую последнюю. Достаточно ли для этого запроса?

Lyess2b 04.06.2018 04:08

@LyessDrille. . . Это то, что делает первый запрос.

Gordon Linoff 04.06.2018 04:18

вы хотите получить обновленную версию или 1. получить идентификатор устройства (из обновления); 2. получить 1 запись с этим идентификатором устройства и самую последнюю? в обоих случаях лучше использовать OUTPUT clausedocs.microsoft.com/en-us/sql/t-sql/queries/…

RizkiDPrast 04.06.2018 04:18

@GordonLinoff ... Спасибо, это то, что мне нужно

Lyess2b 04.06.2018 04:34

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