2

我有一个 Oracle 包,其中有一个过程:

PROCEDURE pGetData(pi_dStartDate IN  date, 
                           pi_dEndDate   IN  date, 
                           po_curData    OUT sys_refcursor,
                           po_nStatus    OUT NUMBER,
                           po_sErrorText OUT VARCHAR2)

如您所见,有一个sys_refcursor输出参数。我已经完成了链接中提到的以下步骤:EntityFrameworkOBE使用 Entityframwork 添加过程。

但是当我从模型浏览器中“添加函数”时,我只得到 4 个参数来传递 DBContext 生成代码中的函数。

        public virtual ObjectResult<pGetData_Result> ProcGetData
        (Nullable<System.DateTime> pI_DSTARTDATE,
         Nullable<System.DateTime> pI_DENDDATE,
         ObjectParameter pO_NSTATUS,
         ObjectParameter pO_SERRORTEXT)
    {
        var pI_DSTARTDATEParameter = pI_DSTARTDATE.HasValue ?
            new ObjectParameter("PI_DSTARTDATE", pI_DSTARTDATE) :
            new ObjectParameter("PI_DSTARTDATE", typeof(System.DateTime));

        var pI_DENDDATEParameter = pI_DENDDATE.HasValue ?
            new ObjectParameter("PI_DENDDATE", pI_DENDDATE) :
            new ObjectParameter("PI_DENDDATE", typeof(System.DateTime));

        return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction<pGetData_Result>
            ("pGetData", pI_DSTARTDATEParameter, pI_DENDDATEParameter, pO_NSTATUS, pO_SERRORTEXT);
    }

我无法通过“ Ref_Cursor ”,因此出现错误:

“ORA-06550:第 1 行,第 8 列:\nPLS-00306:调用 'PGETUTILTSINTILEDATA' 时参数的数量或类型错误\nORA-06550:第 1 行,第 8 列:\nPL/SQL:语句被忽略”

请帮忙。

谢谢。

4

1 回答 1

2

这是我尝试的正确方法。代码没有返回值的唯一问题是我为我的 EDMX 文件创建了一个单独的类库。

要解决这个问题:

转到 EDMX 文件的属性并将“复制到输出目录”设置为“始终复制”。

如果您将 EDMX 文件包含在主可执行应用程序的同一目录中,则不会有任何问题,您可以执行我在上面定义的相同方法。

于 2015-04-16T08:08:25.897 回答