Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Разбить выборку на диапазоны / 4 сообщений из 4, страница 1 из 1
01.12.2019, 23:04
    #39896865
Earl11
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Разбить выборку на диапазоны
Здравствуйте. Имеется таблица в 50 000 записей. Как вывести, например, по 500 записей (последовательно; например, сначала первые 500, потом следующие)? С помощью ROW_NUMBER()?
...
Рейтинг: 0 / 0
01.12.2019, 23:36
    #39896869
zby
zby
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Разбить выборку на диапазоны
...
Рейтинг: 0 / 0
02.12.2019, 00:10
    #39896873
3unknown
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Разбить выборку на диапазоны
Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
if object_id ('tempdb..#t') is not null drop table #t

create  table #t(Id int IDENTITY(1, 1) NOT NULL)

DECLARE @i int = 0;

WHILE @i < 50000 -- insert 100 rows.  change this value to whatever you want.
BEGIN

INSERT #t DEFAULT VALUES
SET @i = @i + 1;

END

select*
from #t
order by id
OFFSET 0 ROWS  
    FETCH NEXT 500 ROWS ONLY

;with a as(
select*
,NTILE(100) over(order by id) n
from #t 
)
select id from a where n=1 
order by id
...
Рейтинг: 0 / 0
02.12.2019, 22:33
    #39897331
Earl11
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Разбить выборку на диапазоны
Спасибо
...
Рейтинг: 0 / 0
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Разбить выборку на диапазоны / 4 сообщений из 4, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]