Как получить номер как псевдоним в оракуле - PullRequest
1 голос
/ 28 марта 2019

У меня есть запрос ниже:

Select 
  Y1 as Cast(v_FY0 - 5 - v_offset as char) 
from 
  TBLTMPLTS_LOAD_INCSTATEMT_RAW;

, где v_FY0 НОМЕР (10) и номер v_OffSet (10);

После выполнения я получаю: v_FY0 =2018 and v_OffSet = 0;

Итак, утверждение становится:

SELECT 
  Y1 as CAST(2018 - 5 - 0 AS CHAR) 
FROM 
  TBLTMPLTS_LOAD_INCSTATEMT_RAW;

По сути, я пытаюсь добиться того, чтобы при выборе столбца Y1 из таблицы TBLTMPLTS_LOAD_INCSTATEMT_RAW имя столбца должно быть вычисленным значением v_FY0 и v_OffSet, как указано в вышеприведенном выражении, и я не могу записать это напрямую, поскольку он выполняется в цикле и в цикле есть разные значения для v_FY0 и v_OffSet, тем самым каждый раз меняя имя столбца в зависимости от значений v_FY0 и v_OffSet.

Но я получаю сообщение об ошибке:

ORA -00923: ключевое слово FROM не найдено там, где ожидается

Как решить эту проблему?

EDIT: Как сказал Каушик Наяк, код, который я представил выше, является частью заявления об отклонении, показанного ниже. Я взял только ту часть, которая, как мне показалось, вызывала проблему, чтобы все ясно поняли.

v_SQL := '
-- ==========================================================
--  Main Unpivot Table -  To move years from column headings 
--  to rows values
-- ==========================================================

SELECT 
 CAST(FieldYear AS Number) FieldYear
, FieldType
, CASE FieldValue 
    WHEN '''' THEN NULL
    ELSE CAST (FieldValue AS Number(38,8))
  END FieldValue
FROM 
(SELECT ' || 
v_InsertType ||' AS FieldType
,Y1 as ' || CAST(v_FY0 - 5 - v_OffSet AS CHAR) || '
,Y2 as ' || CAST(v_FY0 - 4 - v_OffSet AS CHAR) || '
,Y3 as ' || CAST(v_FY0 - 3 - v_OffSet AS CHAR) || '
,Y4 as ' || CAST(v_FY0 - 2 - v_OffSet AS CHAR) || '
,Y5 as ' || CAST(v_FY0 - 1 - v_OffSet AS CHAR) || '
,Y6 as ' || CAST(v_FY0     - v_OffSet AS CHAR) || ' 
,Y7 as ' || CAST(v_FY0 + 1 - v_OffSet AS CHAR) || '
,Y8 as ' || CAST(v_FY0 + 2 - v_OffSet AS CHAR) || '
,Y9 as ' || CAST(v_FY0 + 3 - v_OffSet AS CHAR) || '
,Y10 as ' || CAST(v_FY0 + 4 - v_OffSet AS CHAR) || '
,Y11 as ' || CAST(v_FY0 + 5 - v_OffSet AS CHAR) || '
,Y12 as ' || CAST(v_FY0 + 6 - v_OffSet AS CHAR) || '
,Y13 as ' || CAST(v_FY0 + 7 - v_OffSet AS CHAR) || '
,Y14 as ' || CAST(v_FY0 + 8 - v_OffSet AS CHAR) || '
,Y15 as ' || CAST(v_FY0 + 9 - v_OffSet AS CHAR) || '
,Y16 as ' || CAST(v_FY0 + 10 - v_OffSet AS CHAR) || '
,Y17 as ' || CAST(v_FY0 + 11 - v_OffSet AS CHAR) || '
,Y18 as ' || CAST(v_FY0 + 12 - v_OffSet AS CHAR) || '
,Y19 as ' || CAST(v_FY0 + 13 - v_OffSet AS CHAR) || '
,Y20 as ' || CAST(v_FY0 + 14 - v_OffSet AS CHAR) || '
,Y21 as ' || CAST(v_FY0 + 15 - v_OffSet AS CHAR) || '
,Y22 as ' || CAST(v_FY0 + 16 - v_OffSet AS CHAR) || '
,Y23 as ' || CAST(v_FY0 + 17 - v_OffSet AS CHAR) || '
,Y24 as ' || CAST(v_FY0 + 18 - v_OffSet AS CHAR) || '
,Y25 as ' || CAST(v_FY0 + 19 - v_OffSet AS CHAR) || '
,Y26 as ' || CAST(v_FY0 + 20 - v_OffSet AS CHAR) || '
,Y27 as ' || CAST(v_FY0 + 21 - v_OffSet AS CHAR) || '
,Y28 as ' || CAST(v_FY0 + 22 - v_OffSet AS CHAR) || '
,Y29 as ' || CAST(v_FY0 + 23 - v_OffSet AS CHAR) || '
,Y30 as ' || CAST(v_FY0 + 24 - v_OffSet AS CHAR) || '
,Y31 as ' || CAST(v_FY0 + 25 - v_OffSet AS CHAR) || '
,Y32 as ' || CAST(v_FY0 + 26 - v_OffSet AS CHAR) || '
,Y33 as ' || CAST(v_FY0 + 27 - v_OffSet AS CHAR) || '
,Y34 as ' || CAST(v_FY0 + 28 - v_OffSet AS CHAR) || '
,Y35 as ' || CAST(v_FY0 + 29 - v_OffSet AS CHAR) || '

FROM ' || 
    v_tblInsertType || ') UP
UNPIVOT
(FieldValue FOR FieldYear IN 
(' || CAST(v_FY0 - 5 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 - 4 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 - 3 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 - 2 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 - 1 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0     - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 1 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 2 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 3 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 4 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 5 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 6 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 7 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 8 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 9 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 10 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 11 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 12 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 13 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 14 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 15 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 16 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 17 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 18 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 19 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 20 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 21 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 22 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 23 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 24 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 25 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 26 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 27 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 28 - v_OffSet AS CHAR) || '
,' || CAST(v_FY0 + 29 - v_OffSet AS CHAR) || '
)
)AS unpvt

Execute immediate v_SQL;

Но я получаю ошибку - ORA-00923: ключевое слово FROM не найдено там, где ожидается.

1 Ответ

1 голос
/ 28 марта 2019

Имена столбцов в наборе результатов являются идентификаторами. Идентификаторы должны быть указаны / известны во время подготовки оператора SQL. Невозможно динамически изменять имена столбцов (псевдонимы столбцов) во время выполнения оператора или внутри него.

Нормативный подход к удовлетворению этого типа требований заключается в запуске двух операторов SQL. Результаты первого оператора могут быть использованы при создании текста второго оператора SQL.


EDIT

В полном коде (добавленном в недавнем редактировании вопроса) кажется, что заключительная заключительная одинарная кавычка отсутствует в операторе, который присваивает значение v_SQL.

Похоже, мы бы хотели, чтобы EXECUTE IMMEDIATE был отдельным оператором, а не частью значения, присвоенного v_SQL.

В первоначальном вопросе не было ясно (для меня), что проблема была в контексте блока PL / SQL, т.е. v_offset является ссылкой на переменную PL / SQL, а не на столбец.

Для отладки рассмотрите DBMS_OUTPUT -ing значение v_SQL сразу после назначения.

...