Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Подсчет строк в подзапросе, Сколько было выбрано строк в подзапросе 
:(
    Опции темы
Wilko
Дата 31.8.2011, 08:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 42
Регистрация: 4.5.2008

Репутация: нет
Всего: нет



Всем доброе утро.
Ниже представлена процедура которую использую для создания пейджинга на своей странице. Хотел сделать так, чтобы через еще одну output переменную из запроса возвращалось общее количество строк в подзапросе. Как это можно сделать, @@Rowcount ясное дело тут не поможет.
Код

CREATE PROCEDURE [dbo].[GetQuerys]
(@RowIndex INT ,
@MaxRows INT,
@Employees nvarchar(50) = null,
@RecordCount INT OUTPUT)    
AS
BEGIN
DECLARE @StartRow INT
DECLARE @EndRow INT
 
SET @StartRow = (@RowIndex+1)
SET @EndRow = @StartRow + @MaxRows
    SET NOCOUNT ON;
    SELECT  * FROM (SELECT Q.ID AS Number,E.ShortName,                       
                        ROW_NUMBER() OVER (ORDER BY Q.ID) numberrow                        
                    FROM Queries Q
                        INNER JOIN Employees E ON (E.ID = Q.EmployeeID)                        
                    WHERE E.ID IN (parse(@Employees)) OR @Employees IS NULL                            
                    ) input  
    WHERE input.numberrow BETWEEN @StartRow AND @EndRow
END

Как тут в переменную @RecordCount можно получить количество строк, выбранных в подзапросе?

PM MAIL   Вверх
Kolovorot
Дата 3.10.2011, 11:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 245
Регистрация: 12.1.2009

Репутация: 1
Всего: 3



Может так:
Код

SELECT Q.ID AS Number,E.ShortName,                       
                        ROW_NUMBER() OVER (ORDER BY Q.ID) numberrow,
                        COUNT(*) OVER() AS countrows  
                    FROM Queries Q
                        INNER JOIN Employees E ON (E.ID = Q.EmployeeID)                        
                    WHERE E.ID IN (parse(@Employees)) OR @Employees IS NULL 

--------------------
Никогда еще истина не повисала на руке безусловного. Фридрих Ницше. Так говорил Заратустра
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




[ Время генерации скрипта: 0.0560 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.