sql >> Databáze >  >> RDS >> Oracle

Jak spustit uloženou proceduru v oracle, která obsahuje dva příkazy insert?

Jak chyba říká, předáváte nesprávný počet nebo typ parametrů.

Důrazně doporučuji použít syntaxi pojmenovaného parametru, pokud se pokoušíte volat proceduru s tolika parametry. V opačném případě lidé mívají potíže si všimnout, když vynechají parametr nebo předají parametry ve špatném pořadí, pokud se snaží zjistit, co předají za 20. parametr do procedury. Osobně bych měl tendenci refaktorovat proceduru dlouho předtím, než jsem se snažil předat 20 parametrů. Něco tak jednoduchého, jako je předání jednoho nebo dvou typů záznamů, může kód mnohem snáze přečíst a pochopit.

Změnil jsem vaše volání tak, aby používal pojmenované parametry, a přidal jsem komentáře k tomu, kde jste udělali chyby.

execute new_order(
  p_order_id => 4, -- Pass in a number rather than using implicit conversion
  p_order_num => 'O223PS562', 
  p_name => 'Test Test', 
  p_email => '[email protected]', 
  p_address => '123 Test Street', 
  p_city => 'Newcastle Upon Tyne', 
  p_province => 'Tyne and Wear', 
  p_postcode => 'NE98 4TN', 
  p_telephone => '123456789', 
  p_total => 7.97, -- Pass in a number rather than using implicit conversion
  p_order_date => to_date('11-apr-2021', 'DD-mon-YYYY'), -- Pass in a date rather than using implicit conversion
  p_order_item_id => 5, -- Pass in a number rather than using implicit conversion
  p_product_id => 4, -- Pass in a number rather than using implicit conversion
  p_seller_id => 2, -- Pass in a number rather than using implicit conversion 
  p_sub_order_number => 2, -- Pass in a number rather than using implicit conversion 
  p_quantity => 3073748221, -- Do you really want the quantity to be in the billions?  That seems unlikely.  
                            -- Perhaps there was supposed to be a phone number parameter
  p_condition => '2', -- That doesn't look like a condition.  Probably meant to be a unit price
  p_unit_price => 'Brand new', -- Here we have a definite error.  p_unit_price is a number but you can't connvert
                               -- the string 'Brand new' to a number.  I assume that was really supposed to be the
                               -- condition
  p_cost_charge => 1.99, -- Pass in a number rather than using implicit conversion
  '2.00' -- And here we have a value being passed in but no equivalent parameter
);    



  1. Co je systém správy databází a relačních databází (RDBMS)

  2. Jak připojit lokálně hostovanou databázi MySQL s kontejnerem dockeru

  3. JDBCExceptionReporter - Chyba SQL:0, SQLState:08001

  4. Globální proměnná založená na relaci v uložené proceduře Postgresql?