Oracle中使用“选择命令”和“变量”的存储过程出现错误

本文关键字:变量 错误 存储过程 选择命令 选择 命令 Oracle | 更新日期: 2023-09-27 17:59:37

作为Oracle 11G 的新手,我正在尝试了解Oracle存储过程

这是我的MS SQL存储过程

Create procedure LoadLoginData
@username varchar(50),
@password varchar(50)
as
begin
select * from Employee_table where
username = @username and password = @password
end

当我使用Oracle Scratch Editor时,我得到了这个输出

CREATE OR REPLACE PROCEDURE LoadLoginData
(
  v_username IN VARCHAR2 DEFAULT NULL ,
  v_password IN VARCHAR2 DEFAULT NULL ,
  cv_1 OUT SYS_REFCURSOR
)
AS
BEGIN
   OPEN  cv_1 FOR
      SELECT * 
        FROM employee_table 
        WHERE Username = v_username
                AND PASSWORD = v_password ;
END;

当我在C#中调用Oracle过程时,它抛出了这个异常

"ORA-06550:第1行第7列:PLS-00306:错误的编号或类型调用'LOADLOGINDATA'ORA-06550:第1行第7列:"

知道怎么解决这个问题吗?

我的C#代码

OracleConnection ocon = new OracleConnection(orastr);
        OracleCommand ocmd = new OracleCommand("LoadLoginData", ocon);
        ocmd.CommandType = CommandType.StoredProcedure;
        ocon.Open();
        try
        {
            ocmd.Parameters.Add("Username", nBo.username);
            ocmd.Parameters.Add("Password", nBo.password);
            OracleDataAdapter oda = new OracleDataAdapter(ocmd);            
            DataSet ds = new DataSet();
            oda.Fill(ds);
            DataTable dt = ds.Tables[0];
            return dt;
        }
        catch (Exception ex)
        {
            throw ex;
        }
        finally
        {
            ocon.Dispose();
            ocon.Close();
            nBo = null;
        }

Oracle中使用“选择命令”和“变量”的存储过程出现错误

您的过程2个输入参数和1个输出参数。。。。您的C#代码有2个输入参数,但没有输出参数

Java级别中,我会以以下方式处理它:

callableStatement.registerOutParameter(3, OracleTypes.CURSOR);

C#中,请寻找相同的东西(如何处理)。。。我建议

ocmd.Parameters.Add("cv_1", OracleDbType.RefCursor, ParameterDirection.Output);