Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2002.05.09;
Скачать: [xml.tar.bz2];

Вниз

Как подставить значение поля в sql-запрос   Найти похожие ветки 

 
bos   (2002-04-11 17:23) [0]

Есть таблица, в которой одно из полей (TABLENAME) тип varchar содежит названия других таблиц;
как в запросе получив значение TABLENAME, пусть это будет "table1", получить данные из таблицы table1?
все крутится на Interbase 6


 
Johnmen   (2002-04-11 17:29) [1]

Только несколькими запросами.
Первый вытаскивает названия таблиц, остальные формируются динамически, и только так !


 
bos   (2002-04-11 18:01) [2]

:(
А в хранимой процедуре?


 
Леха_   (2002-04-11 18:08) [3]

В хранимой процедуре без проблем


 
kaif   (2002-04-11 21:25) [4]

>Леха_ (11.04.02 18:08)
>В хранимой процедуре без проблем

Да?????????
А как конкретно?



 
Deniz   (2002-04-12 06:10) [5]

На клиенте без проблем

Query1.SQL.Clear;
Query1.SQL.Add("select * from "+TableName);
Query1.Open;

В хранимой процедуре такое не пойдет. Если заранее известен список таблиц, то путем перебора:

Create procedure ProcName(TableName varchar(25))
returns (...)
as begin
if (:TableName = "Table1") then
select * from Table1 into ...;
if (:TableName = "Table2") then
select * from Table2 into ...;
if (:TableName = "Table3") then
select * from Table3 into ...;
...
suspend;
end;

А если список таблиц не известен, то увы...


 
roottim   (2002-04-12 08:35) [6]

хоть ХП, хоть на клиенте.. всеравно запрос будет составлен динамически на основе другого!
лучший вариант конечно Johnmen © (11.04.02 17:29)


 
kaif   (2002-04-16 13:23) [7]

Правильный ответ только у Deniz © (12.04.02 06:10).
В IB макроподстановка имени таблицы в запрос в хранимой процедуре не допускается. На клиенте - без проблем.



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

Форум: "Базы";
Текущий архив: 2002.05.09;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.005 c
1-26088
Alibaba
2002-04-26 15:35
2002.05.09
Мой тип.


1-26065
VS2001
2002-04-18 18:15
2002.05.09
Как высчитать интервал прошедшего времени в минутах


1-26144
Andreika
2002-04-24 22:24
2002.05.09
CreateProcess и все такое...


14-26263
IronHawk
2002-04-02 15:39
2002.05.09
Приветствую Мастеров ! Есть вопрос, мне надо сохранять дату из


1-26138
CoRpse
2002-04-24 16:36
2002.05.09
Помогите найти!!!





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский