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;
}
您的过程有2个输入参数和1个输出参数。。。。您的C#代码有2个输入参数,但没有输出参数
在Java级别中,我会以以下方式处理它:
callableStatement.registerOutParameter(3, OracleTypes.CURSOR);
在C#中,请寻找相同的东西(如何处理)。。。我建议
ocmd.Parameters.Add("cv_1", OracleDbType.RefCursor, ParameterDirection.Output);