Главная страница
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.011 c
14-69575
AL2002
2002-11-01 15:50
2002.11.21
Как пользоваться SoftIce?


3-69148
Jony
2002-10-30 20:57
2002.11.21
Как передать несколько параметров в запросе следующей конструкции


14-69510
Николай Быков
2002-11-01 20:12
2002.11.21
Чтобы не было мучительно больно.............


3-69214
Дмитрий
2002-10-30 08:00
2002.11.21
Blob-поле


1-69343
antonioxxx
2002-11-11 12:54
2002.11.21
---|Ветка была без названия|---