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

Вниз

Переменная вместо имени поля в запросе.   Найти похожие ветки 

 
sunwheel ©   (2002-11-01 14:16) [0]

Возможно ли использовать переменную вместо имени поля в запросе, в хранимой процедуре? Делаю примерно так:


CREATE PROCEDURE GETNEXTNUMBER (
FIELDNAME VARCHAR(254))
RETURNS (
RESULT INTEGER)
AS
DECLARE VARIABLE FFIELDNAME INTEGER;
begin
FIELDNAME = "F_IDNkl1"; /* Это для примера */
SELECT :FIELDNAME FROM IDNUMS
WHERE F_FIRST=1
INTO :FFIELDNAME;
...


На SELECT"е вылетает ошибка "Invalid variant type conversion"
Хотелось бы знать возможно ли вообще, как-либо, использовать переменные в качестве имени поля в запросах. Буду признателен за любой совет или ссылку.


 
Johnmen ©   (2002-11-01 14:24) [1]

Нельзя. Т.к. фактически это не параметр, а макроподстановка.


 
Alexandr ©   (2002-11-01 14:24) [2]

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


 
sunwheel ©   (2002-11-01 14:35) [3]

>Johnmen © (01.11.02 14:24)
Хреново, что нельзя, а так было бы все просто. :(

>Alexandr © (01.11.02 14:24)
Не совсем тебя понял, не мог бы ты на каком-нибудь примере пояснить?


 
Alexandr ©   (2002-11-01 14:41) [4]

CREATE PROCEDURE GETNEXTNUMBER (
FIELDNAME VARCHAR(254))
RETURNS (
RESULT INTEGER)
AS
DECLARE VARIABLE FFIELDNAME1 INTEGER;
DECLARE VARIABLE FFIELDNAME2 INTEGER;
DECLARE VARIABLE FFIELDNAME3 INTEGER;
DECLARE VARIABLE FFIELDNAME4 INTEGER;
DECLARE VARIABLE FFIELDNAME INTEGER;
begin
FIELDNAME = "F_IDNkl1"; /* Это для примера */
SELECT F_IDNkl1,F_IDNkl2,F_IDNkl3,F_IDNkl4 FROM IDNUMS
WHERE F_FIRST=1
INTO :FFIELDNAME1,:FFIELDNAME2,:FFIELDNAME3,:FFIELDNAME4;
if FIELDNAME="F_IDNkl1" then ffieldname=ffieldname1;
if FIELDNAME="F_IDNkl2" then ffieldname=ffieldname2;
if FIELDNAME="F_IDNkl3" then ffieldname=ffieldname3;
if FIELDNAME="F_IDNkl4" then ffieldname=ffieldname4;
....

теперь-то понял?



 
sunwheel ©   (2002-11-01 14:47) [5]

Спасибо, теперь понятно. Но это не то, что мне нужно, забыл сказать, что в таблице количество полей не постоянно. Ну что ж, придется через UDF все это реализовывать. :(
Всем спасибо.


 
Alexandr ©   (2002-11-01 14:50) [6]

не понял, как это "количество полей в таблице непостоянно".
и не понял, как эту задачу решить с помощью udf.

А впрочем, и фиг с ней.



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

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

Наверх




Память: 0.48 MB
Время: 0.019 c
3-69160
MsGuns
2002-10-29 15:48
2002.11.21
Неудобоваримый LookUp или я родился баобабом


1-69275
Chlavik
2002-11-12 00:39
2002.11.21
Как програмно развенуть ComboBox?


1-69421
Tornado
2002-11-11 11:06
2002.11.21
Flash


1-69445
BALU1111
2002-11-11 15:40
2002.11.21
TListVeiw


3-69170
battar
2002-10-24 22:25
2002.11.21
fastreport