Я пытаюсь выполнить процедуру Oracle из C #, но ExecuteReader
выдает ошибку:
ORA-01840: входное значение недостаточно длинное для формата даты.
Если я выполню процедуру с «данными, записанными» в предложении WHERE, она будет работать хорошо, но не тогда, когда в предложении WHERE используются параметры.
Это нормально:
rigrif.rig_dmov BETWEEN TO_DATE('03/04/2019', 'dd/MM/yyyy') AND TO_DATE('03/04/2019','dd/MM/yyyy')
Это не нормально:
rigrif.rig_dmov BETWEEN TO_DATE(p_date_from, 'dd/MM/yyyy') AND TO_DATE(p_date_to,'dd/MM/yyyy')
// C # код
public IEnumerable<StockMovements> GetGeneralStockVega(FilterStockValidator value)
{
List<StockMovements> list = new List<StockMovements>();
try
{
Connection ObjCn = new Connection();
using (OracleConnection connection = new OracleConnection(ObjCn.getConnectionString()))
{
OracleCommand command = new OracleCommand(StoredProcedures.sp_Get_GeneralStockVega, connection);
command.CommandType = CommandType.StoredProcedure;
command.Parameters.Add("p_filial", OracleDbType.Varchar2, 2).Value = "18";
command.Parameters.Add("p_date_from", OracleDbType.Varchar2, 22).Value = "03/04/2019";
command.Parameters.Add("p_date_to", OracleDbType.Varchar2, 22).Value ="04/04/2019";
command.Parameters.Add("p_respuesta", OracleDbType.RefCursor).Direction = ParameterDirection.Output;
connection.Open();
OracleDataReader reader = command.ExecuteReader();
StockMovements objStock = null;
while (reader.Read())
{
objStock = new StockMovements();
objStock.FechaMovimiento = reader["fecha_movimiento"].ToString();
objStock.Almacen = reader["almacen"].ToString();
objStock.CantidadVega = decimal.Parse(reader["cantidad"].ToString());
objStock.Documento = reader["documento"].ToString();
list.Add(objStock);
}
}
return list;
}
catch (Exception ex)
{
Logs.RegError(ex, this.GetType());
return null;
}
}
Код процедуры:
PROCEDURE get_vega_general_stock (
p_date_from IN VARCHAR2,
p_date_to IN VARCHAR2,
p_filial IN VARCHAR2,
p_respuesta OUT SYS_REFCURSOR
)
IS
BEGIN
OPEN p_respuesta FOR
SELECT
TRUNC(rigrif.rig_dmov) AS fecha_movimiento,
rigrif.rig_fili AS almacen,
rigrif.rig_mag AS almacen_office,
testrif.tst_doc AS documento,
SUM(rigrif.rig_qta) AS cantidad
FROM
rigrif rigrif
INNER JOIN detrif detrif
ON rigrif.rig_det = detrif.det_prg
INNER JOIN prodotti prodotti
ON rigrif.rig_pro = prodotti.pro_cod
INNER JOIN testrif testrif
ON rigrif.rig_testrif = testrif.tst_prg
WHERE
detrif.det_del = 'E'
AND prodotti.pro_grp = 0
AND rigrif.rig_fili = '18'
AND rigrif.rig_dmov BETWEEN TO_DATE(p_date_from, 'dd/MM/yyyy' ) AND TO_DATE(p_date_to,'dd/MM/yyyy')
GROUP BY
TRUNC(rigrif.rig_dmov),
rigrif.rig_fili,
rigrif.rig_mag,
testrif.tst_doc
ORDER BY
1,2,3,4;
END get_vega_general_stock;