Главная страница
    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-26153
hogus
2002-04-24 19:21
2002.05.09
Указатели в функции?????????????


14-26258
PVOzerski
2002-04-02 11:38
2002.05.09
Чем занят комп в


3-26045
Alex G
2002-04-15 03:02
2002.05.09
А можно посредством SQL ...


4-26305
Delphimun
2002-03-08 08:47
2002.05.09
WinApi in Masm32


14-26270
Donal_Graeme
2002-04-02 10:00
2002.05.09
Kylix





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский