oracle-databaseloopsplsqlnestedplsqldeveloper

"ORA_00913 Oracle Error - Too many values" when inserting values


The below code is in stored procedure, and they told me to convert it into nested loops and try running it.

insert into PRICEVIEW_RATE_PLAN_PROC (
    SSR_CODE
    ,CORRIDOR_PLAN_ID
    ,CORRIDOR_PLAN_DESCRIPTION
    ,USAGE_TYPE
    ,PRODUCT
    ,JURISDICTION
    ,PROVIDER
    ,RATE_PERIOD
    ,FLAGFALL
    ,RATE
    ,RATEBAND
    ,NUMSECS
    ,BAND_RATE
    ,ACTIVE_DT
    ,INACTIVE_DT
    )
select /*+ use_hash(rate_usage_overrides,corridor_plan_id_values,product_elements,descriptions,jurisdictions,rate_usage_bands_overrides) */
    distinct decode(a.corridor_plan_id, 0, '''', (
            select c.short_display
            from corridor_plan_id_values c
            where a.corridor_plan_id = c.corridor_plan_id
            )) as SSR_CODE
    ,a.corridor_plan_id as CORRIDOR_PLAN_ID
    ,decode(a.corridor_plan_id, 0, '''', (
            select d.display_value
            from corridor_plan_id_values d
            where a.corridor_plan_id = d.corridor_plan_id
            )) as CORRIDOR_PLAN_DESCRIPTION
    ,decode(a.type_id_usg, 0, '''', (
            select f.description_text
            from usage_types e
                ,descriptions f
            where a.type_id_usg = e.type_id_usg
                and e.description_code = f.description_code
            )) as USAGE_TYPE
    ,decode(a.element_id, 0, '''', (
            select h.description_text
            from product_elements g
                ,descriptions h
            where a.element_id = g.element_id
                and g.description_code = h.description_code
            )) as PRODUCT
    ,decode(a.jurisdiction, 0, '''', (
            select j.description_text
            from jurisdictions i
                ,descriptions j
            where a.jurisdiction = i.jurisdiction
                and j.description_code = i.description_code
            )) as JURISDICTION
    ,decode(a.provider_class, 0, '''', (
            select k.display_value
            from provider_class_values k
            where a.provider_class = k.provider_class
            )) as PROVIDER
    ,decode(a.rate_period, '' 0 '', '''', (
            select l.display_value
            from rate_period_values l
            where a.rate_period = l.rate_period
            )) as RATE_PERIOD
    ,(a.FIXED_CHARGE_AMT / 100) + (a.ADD_FIXED_AMT / 10000000) as FLAGFALL
    ,(a.ADD_UNIT_RATE / 10000000) * 60 as RATE
    ,b.RATEBAND as RATEBAND
    ,b.NUM_UNITS as NUMSECS
    ,(b.UNIT_RATE / 10000000) * 60 as BAND_RATE
    ,a.ACTIVE_DT as ACTIVE_DT
    ,a.INACTIVE_DT as INACTIVE_DT
from rate_usage_overrides a
    ,rate_usage_bands_overrides b
where a.seqnum = b.seqnum(+);

I converted above code to nested loop and please find below converted nested loop and When I try to run this script below, it is prompting me an error: too many values. Can you tell me what exactly problem is

insert into PRICEVIEW_RATE_PLAN_PROC(
  SSR_CODE,
  CORRIDOR_PLAN_DESCRIPTION,
  USAGE_TYPE,
  PRODUCT,
  JURISDICTION,
  PROVIDER,
  RATE_PERIOD,
  FLAGFALL,
  RATE,
  RATEBAND,
  NUMSECS,
  BAND_RATE,
  ACTIVE_DT,
  INACTIVE_DT
) VALUES (

  (select c.short_display AS SSR_CODE from rate_usage_overrides a,corridor_plan_id_values c where a.corridor_plan_id = c.corridor_plan_id),

  (select d.display_value AS CORRIDOR_PLAN_DESCRIPTION from rate_usage_overrides a ,corridor_plan_id_values d where a.corridor_plan_id = d.corridor_plan_id),

  (select f.description_text AS USAGE_TYPE from rate_usage_overrides a ,usage_types e, descriptions f where a.type_id_usg = e.type_id_usg and e.description_code = f.description_code ),

  (select h.description_text AS PRODUCT from rate_usage_overrides a, product_elements g,descriptions h where a.element_id = g.element_id and g.description_code = h.description_code ),

  (select j.description_text AS JURISDICTION from rate_usage_overrides a, jurisdictions i,descriptions j where a.jurisdiction = i.jurisdiction and j.description_code = i.description_code),

  (select k.display_value AS PROVIDER from rate_usage_overrides a ,provider_class_values k where a.provider_class = k.provider_class),

  (select l.display_value AS RATE_PERIOD from rate_usage_overrides a ,rate_period_values l where a.rate_period = l.rate_period),

  (select (a.FIXED_CHARGE_AMT/100) + (a.ADD_FIXED_AMT/10000000) AS FLAGFALL from rate_usage_overrides a AS ACTIVE_DT),

  (select (a.ADD_UNIT_RATE/10000000) * 60 AS RATE from rate_usage_overrides a),

  (select b.RATEBAND AS RATEBAND from rate_usage_bands_overrides b),

  (select b.NUM_UNITS AS NUMSECS from rate_usage_bands_overrides b),

  (select (b.UNIT_RATE/10000000) * 60 AS BAND_RATE from rate_usage_bands_overrides b),

  (select a.ACTIVE_DT,a.seqnum,b.seqnum  AS ACTIVE_DT from rate_usage_overrides a, rate_usage_bands_overrides b where a.seqnum = b.seqnum(+)),

  (select a.INACTIVE_DT,a.seqnum,b.seqnum  AS INACTIVE_DT from rate_usage_overrides a, rate_usage_bands_overrides b where a.seqnum = b.seqnum(+))

Solution

  • Here is your mistake

    (select a.ACTIVE_DT,a.seqnum,b.seqnum  AS ACTIVE_DT from rate_usage_overrides a, rate_usage_bands_overrides b where a.seqnum = b.seqnum(+)),
    
      (select a.INACTIVE_DT,a.seqnum,b.seqnum  AS INACTIVE_DT from rate_usage_overrides a, rate_usage_bands_overrides b where a.seqnum = b.seqnum(+))
    

    both the query will return 3 field but insert specify only one column that's why you are getting this error. and by the way this is not a bug