Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2008.08.31;
Скачать: CL | DM;

Вниз

Формирование запроса с условием TOP   Найти похожие ветки 

 
harisma   (2008-03-01 15:17) [0]

Господа мастера.
Есть некоторый набор последовательных запросов, оформленных в виде одного скрипта. Среди этих запросов есть и такой

SELECT TOP <переменная, вычисленная заранее в этом скрипте> FIELD1, FIELD2  ... FROM TABLE WHERE ....

Возник вопрос: Как правильно подставить в запрос эту переменную?

Говорю сразу - вариант типа

declare @s varchar(...)
set @s = "select top " + @переменная + " FIELD1, FIELD2 FROM ..."
exec (@S)

не предлагать!!!


 
b z   (2008-03-01 16:09) [1]

SELECT TOP(<переменная, вычисленная заранее в этом скрипте>) FIELD1, FIELD2  ... FROM TABLE WHERE ....


 
harisma   (2008-03-01 16:16) [2]

А ты это пробовал? Так не работает.


 
b z   (2008-03-01 16:19) [3]

2005 на ура
или SET ROWCOUNT <переменная, вычисленная заранее в этом скрипте>
и не забыть "скинуть" в конце


 
harisma   (2008-03-01 16:34) [4]

А в SQL 2000 ругается
Line 1: Incorrect syntax near "(".

при коде

select top(5) RecID from dictionaries_C3AD665D2FD8E140 as D


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


 
salexn   (2008-03-01 18:02) [5]

попробуй сначала
SET ROWCOUNT
потом селект
затем
SET ROWCOUNT 0 (чтобы больше не было ограничений)


 
harisma   (2008-03-01 18:27) [6]


> попробуй сначала
> SET ROWCOUNT
> потом селект

Так в принципе работает, но для моей задачи не подходит. Дело в том, что этот запрос с условием TOP я хочу использовать в следующей конструкции:

SELECT ... FROM TABLE_1
WHERE ... AND (FIELD1 IN (SELECT TOP <Число записей> FIELD1 FROM TABLE_2...)) AND (FIELD2 IN (SELECT TOP <> FIELD2 FROM TABLE_3 WHERE ...))

Все это должно работать под SQL 2000 и даже SQL 7.0, так что варианты для SQL 2005 не предлагать.
А может кто имеет что предложить как вообще такой скрипт по другому переписать, чтоб не иметь этих менингитов с TOP?


 
DiamondShark ©   (2008-03-03 17:02) [7]


> harisma   (01.03.08 18:27) [6]

выбирай сначала во временные таблицы



Страницы: 1 вся ветка

Текущий архив: 2008.08.31;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.012 c
2-1216799306
Квэнди
2008-07-23 11:48
2008.08.31
Сообщений Windows на открытие URL


15-1215818767
Kostafey
2008-07-12 03:26
2008.08.31
С днем рождения ! 12 июля


8-1184852812
Забыл_ник
2007-07-19 17:46
2008.08.31
Регулировать уровень записи (громкость) на микрофоне


3-1204794614
patrick1968
2008-03-06 12:10
2008.08.31
из ADO в PARADOX


15-1215634451
@!!ex
2008-07-10 00:14
2008.08.31
CALLBACk процедура как часть класса в С++