ora-01036 Недопустимая переменная имя / номер Вызов ExecuteNonQuery с использованием VB.Net
У меня проблема с выполнением запроса Oracle через.NET. Я совершенно новичок в вызове команд Oracle из.Net, (я из опыта работы с MySQL), поэтому любая помощь очень ценится!
Сначала я строю строку запроса...
declare
pDate date;
pErrorCode binary_integer;
pErrorInfo varchar2(500);
begin
date := to_date(:Date, 'YYYY-MM-DD');
AnUpdateRoutine(:VehicleID, :ContractID, :DriverID, :pDate, :pDriverContribution, pErrorCode, pErrorInfo);
end;
Затем я добавляю свои параметры...
cmd2.Parameters.Add(":VehicleID", OracleDbType.Int32).Value = CInt(HiddenField.Get("ID"))
cmd2.Parameters.Add(":ContractID", OracleDbType.Int32).Value = CInt(HiddenField.Get("ContractID"))
cmd2.Parameters.Add(":DriverID", OracleDbType.Int32).Value = CInt(cbCurrentDriver.Value)
cmd2.Parameters.Add(":pDate", OracleDbType.Date).Value = Date.Now()
cmd2.Parameters.Add(":pDriverContribution", OracleDbType.NVarchar2).Value = DBNull.Value
cmd2.Parameters.Add("pErrorCode", OracleDbType.NVarchar2).Value = 0
cmd2.Parameters.Add("pErrorInfo", OracleDbType.NVarchar2).Value = 0
cmd2.ExecuteNonQuery()
При вызове ExecuteNonQuery() я получаю исключение... ORA-01036: недопустимое имя / номер переменной
Определение для процедуры
procedure AnUpdateRoutine(pVehicleID in T_FM_VEHICLE.F_VEH_ID%type,
pContractID in T_FM_CONTRACT.F_CON_ID%type,
pDriverID in T_FM_DRIVER.F_DVR_ID%type,
pDateTimeOn in date,
pDriverContribution in T_FM_DRIVER_CHG.F_DCH_DVR_CONTRIBUTION%type,
pErrorCode out binary_integer,
pErrorInfo out TErrorInfo);
pVehicleID, pContractID, pDriverID и pDateTimeOn являются обязательными.
1 ответ
Я могу ошибаться, потому что прошло уже много времени с тех пор, как мне навязали Оракула, но...
pErrorCode должен быть:pErrorCode
Та же проблема с:pErrorInfo?