ExecuteReader скинуть ORA-01840 но из sqlDeveloper работает хорошо - PullRequest
0 голосов
/ 25 апреля 2019

Я пытаюсь выполнить процедуру 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;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...