Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
Вариация на тему "SELECT выборкой от N до М записей"
|
|||
|---|---|---|---|
|
#18+
Как основу для запроса взял вариант, который предлагал Glory в одной из подобных тем. Разница заключается в том, что мне нужно сделать выборку не по ID, а по дате. Сейчас у меня сделано так: \n declare @time datetime set @time = GETDATE() SELECT MsgID AS OrigId, @time as lst INTO #tmp1 FROM tblCppMessages where ParentID = 0 group by MsgID update #tmp1 set lst=LastChange FROM tblCppMessages where MsgID = OrigId SELECT identity(int, 1,1) AS RowNum, OrigId AS OrigId INTO #tmp2 FROM #tmp1 order by lst desc drop table #tmp1 SELECT OrigId AS [ID] FROM #tmp2 where RowNum between (@rec_per_page * (@page_num-1) +1) AND (@rec_per_page * (@page_num)) DROP TABLE #tmp2 Т.е. к примеру есть несколько записей у которых MsgID один и тот же, дата обновления разная и только у одной записи ParentID = 0. (чтобы нагляднее понять можете заглянуть на http://www.cppforum.net в любой из форумов) Так вот, можно ли каким то образом в первом селекте скопировать так же и дату сообщения? Т.е. обойтись без Update ? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 13.02.2002, 10:38 |
|
||
|
Вариация на тему "SELECT выборкой от N до М записей"
|
|||
|---|---|---|---|
|
#18+
Ок, пока писал сам понял где можно подкрутить \n SELECT MsgID AS OrigId, LastChange as lst INTO #tmp1 FROM tblCppMessages where ParentID = 0 SELECT identity(int, 1,1) AS RowNum, OrigId AS OrigId INTO #tmp2 FROM #tmp1 order by lst desc drop table #tmp1 SELECT OrigId AS [ID] FROM #tmp2 where RowNum between (@rec_per_page * (@page_num-1) +1) AND (@rec_per_page * (@page_num)) DROP TABLE #tmp2 Можно ли еще как то оптимизировать запрос ? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 13.02.2002, 10:51 |
|
||
|
|

start [/forum/topic.php?fid=46&gotonew=1&tid=1823921]: |
0ms |
get settings: |
11ms |
get forum list: |
19ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
39ms |
get topic data: |
14ms |
get first new msg: |
9ms |
get forum data: |
4ms |
get page messages: |
46ms |
get tp. blocked users: |
2ms |
| others: | 259ms |
| total: | 411ms |

| 0 / 0 |
