0

PL/SQLで次のコードを使用して、文字列を日付に変換しようとしています:

BEGIN
   vfrom := TO_DATE ('20/08/2013', 'dd/mm/yyyy');
   vto := TO_DATE ('30/08/2013', 'dd/mm/yyyy');

   OPEN L_CURSOR FOR
      SELECT DSAT.ORGANIZATION_ID,
             APPS.DAW_INV_ORG_NAME (DSAT.ORGANIZATION_ID) ORGANIZATION_NAME,
             APPS.DAW_CAT_NAME (MC.SEGMENT4) PRODUCT,
             TRUNC (NVL (DSAT.SCH_END_DATE, DSAT.SCH_START_DATE))
                TRANSACTION_DATE,
             TO_CHAR (NVL (DSAT.SCH_END_DATE, DSAT.SCH_START_DATE),
                      'MM-YYYY')
                MONTH,
             DSAT.ITEM_SEGMENTS ITEM_CODE,
             DSAT.ITEM_DESCRIPTION,
             DSAT.CURRENT_FORECAST_QUANTITY PLAN_QTY
        FROM APPS.DAW_SCPDB_ASCP_TPP_V DSAT,
             APPS.MTL_ITEM_CATEGORIES MIC,
             APPS.MTL_CATEGORIES MC
       WHERE     NVL (SCH_END_DATE, SCH_START_DATE) BETWEEN '$(vfrom)'
                                                        AND '$(vto)'
             AND MIC.CATEGORY_SET_ID = 1100000061         --- PLANING CATEGORY
             AND MC.CATEGORY_ID = MIC.CATEGORY_ID
             AND DSAT.INVENTORY_ITEM_ID = MIC.INVENTORY_ITEM_ID
             AND DSAT.ORGANIZATION_ID = MIC.ORGANIZATION_ID
             AND DSAT.FORECAST_SET = '$(vForecastSetDPL2)'; --- Need to Update it on Monthly Basis;
END PorductPlanningForecast;

エラーは次のように発生します

ORA-01858: 29行目で数値が必要な場所に数値以外の文字が見つかりました

これは、クエリのカーソルを開くことで構成されます。NSL パラメーターを確認し、ここで to_Date 関数の形式に日付を設定し、インターネット全体で検索しましたが、まだわかりません。助けてください。

4

1 に答える 1