SQL добавить условный запрос - PullRequest
0 голосов
/ 27 мая 2019

В таблице в моей базе данных у меня есть 12 столбцов, month_1 .... month_12.

Я хочу добавить условный запрос в мой SQL-запрос, если @m = 1 сделает

CREATE PROCEDURE XemDiem_Top5Month1
    @m INT
AS
BEGIN
    SELECT *
    FROM XemDiem
    WHERE (month_1 IN (SELECT TOP (5) month_1
                       FROM XemDiem 
                       GROUP BY month_1
                       ORDER BY month_1DESC))
END

если @m = 2 будет делать

CREATE PROCEDURE XemDiem_Top5Month1
    @m INT
AS
BEGIN
    SELECT *
    FROM XemDiem
    WHERE (month_2 IN (SELECT TOP (5) month_2
                       FROM XemDiem 
                       GROUP BY month_2
                       ORDER BY month_2 DESC))
END

и т. Д.

Я не хочу писать слишком много запросов, поэтому, пожалуйста, помогите

Ответы [ 2 ]

0 голосов
/ 27 мая 2019
declare @ishistoric varchar(100) ='month_1'
(SELECT *
FROM XemDiem
WHERE 
(
 CASE @ishistoric
                  WHEN 'month_1' THEN month_1
                  WHEN 'month_2' THEN month_2
                  ...
                  WHEN 'month_12' THEN month_12
             END  IN 
(
SELECT TOP (5) CASE @ishistoric
                  WHEN 'month_1' THEN month_1
                  WHEN 'month_2' THEN month_2
                  ...
                  WHEN 'month_12' THEN month_12
             END
FROM OSUSR_KIA_PRINTSTICKER 
GROUP BY  CASE @ishistoric
                  WHEN 'month_1' THEN month_1
                  WHEN 'month_2' THEN month_2
                  ...
                  WHEN 'month_12' THEN month_12
             END
ORDER BY CASE @ishistoric
                  WHEN 'month_1' THEN month_1
                  WHEN 'month_2' THEN month_2
                  ...
                  WHEN 'month_12' THEN month_12
             END DESC
)
))

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

0 голосов
/ 27 мая 2019

Присвойте запрос на выборку строке и объедините ваш параметр. Наконец, выполните строку.

Create proc XemDiem_Top5Month1
@m int
AS
BEGIN
Delcare @query nvarchar(max) 
set @query='SELECT *
FROM XemDiem
WHERE 
(
  month_''+Convert(varchar(10),@m)+'' IN 
  (
    SELECT TOP (5) month_''+Convert(varchar(10),@m)+''
    FROM XemDiem 
    GROUP BY month_''+Convert(varchar(10),@m)+''
    ORDER BY month_''+Convert(varchar(10),@m)+'' DESC
  )
)'
execute(@query)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...