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

Вниз

SQL: имя таблицы - параметр   Найти похожие ветки 

 
Karburator   (2007-12-19 11:45) [0]

Пожалуйста помогите - не могу написать хранимую процедуру с запросом в котором вместо конкретного имени таблицы после FROM, будет указан параметр через который это имя будет передаваться,
т.е. что-то типа того:
...
   select count(*)
   from  :TEMP_TABL   /* Parsing error! */
   into :OUT_COLREC
...


 
Desdechado ©   (2007-12-19 11:47) [1]

Так нельзя. Используй execute, но это дурной тон.


 
Sergey13 ©   (2007-12-19 11:56) [2]

> [0] Karburator   (19.12.07 11:45)

У тебя так много временных таблиц? За проектирование тебе двойка! 8-)


 
Andrey ©   (2007-12-19 12:43) [3]

Ога, execute statement или execute block... но, если по хорошему, лучше сразу яйца оторвать.


 
Karburator   (2007-12-19 13:30) [4]

Спасибо. А проект не мой. Хотел провести кой-какой анализ БД используя ее системные таблицы (пока RDB$RELATIONS и RDB$RELATION_FIELDS). А где можно найти информацию о execute statement или execute block? Я нашел только такой синтаксис команды :
EXECUTE PROCEDURE name [param [, param ...]];


 
Desdechado ©   (2007-12-19 13:42) [5]

В ReleaseNotes.pdf


 
PEAKTOP ©   (2007-12-19 14:39) [6]

> Пожалуйста помогите - не могу написать хранимую процедуру  с запросом в котором вместо конкретного имени таблицы после FROM, будет указан параметр через который это имя будет передаваться,

Тебе сюда http://delphimaster.net/view/3-1196414781/
смотри пост №5, там идея указана, обработаешь напильником под себя

> где можно найти информацию о execute statement или execute block?

В фирменной документации
($firebird)/doc/sql.extensions/README.execute_block.txt
($firebird)/doc/sql.extensions/README.execute_statement.txt


 
Karburator   (2007-12-20 08:04) [7]

получилось :), мой пример:
...
   TMP_SQL = "SELECT  count(*)  FROM " || :OUT_TABL;
   EXECUTE STATEMENT :TMP_SQL  INTO :OUT_COLREC;
...
всем спасибо и отдельное РЕАКТОР-у

а вот про
execute block
я информации не нашел, может данная конструкция во 2й версии существует? (у меня ФБ1.5.5)


 
ЮЮ ©   (2007-12-20 09:33) [8]

> получилось :), мой пример:


А теперь вызвать твою процедуру с параметром OUT_TABL, равным  

<имя таблицы> DELETE FROM <имя таблицы> SELECT  count(*) FROM <имя таблицы>

и удивляться, почему записей всегда 0 :)



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

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

Наверх




Память: 0.48 MB
Время: 0.017 c
15-1207823137
Kolan
2008-04-10 14:25
2008.05.25
Интересно, а можно посмотреть Compiler Magic?


8-1180605331
gost`
2007-05-31 13:55
2008.05.25
срочная проблема


6-1186129295
ratmir
2007-08-03 12:21
2008.05.25
Как программно поменять IP


15-1206729020
easy
2008-03-28 21:30
2008.05.25
PDA RO шлюз форума


2-1209362459
Джо__
2008-04-28 10:00
2008.05.25
Извлечение даты