从C#内部调用PL_SQL函数

时间:2018-11-08 21:38:29

标签: c# oracle visual-studio oracle11g

我创建了一个PL / SQL函数并将其存储在我的oracle数据库中。现在,我想在单击按钮时调用该函数。 我正在使用Visual Studio和C#。

我谦虚的尝试-

private void button3_Click(object sender, EventArgs e)
{
    comm = new OracleCommand();
    comm.CommandType = CommandType.StoredProcedure;
    comm.Connection = conn;
    String x1 = textBox1.Text;
    String x2 = textBox2.Text;

    comm.CommandText = "log_in";
    comm.Parameters.Add(new OracleParameter("c", OracleDbType.Varchar2, textBox1.Text, ParameterDirection.Input));
    comm.Parameters.Add(new OracleParameter("tt", OracleDbType.Varchar2, 256, ParameterDirection.ReturnValue));
    String z = comm.Parameters["z"].Value.ToString();
    comm.ExecuteNonQuery();
    if (z.Equals('1'))
    { MessageBox.Show("correct"); }
    conn.Close();
}

PL / SQL-

CREATE OR REPLACE FUNCTION log_in
(
    x IN VARCHAR2,
    y IN VARCHAR2
) RETURN VARCHAR2 AS
    match_count NUMBER;
BEGIN
    SELECT COUNT(*)
    INTO match_count
    FROM student_login
    WHERE email = x
    AND password = y;
    IF match_count = 0 THEN
        RETURN 0;
    ELSE
        RETURN 1;
    END IF;
END;

note-my数据源是oracle的.NET Framework数据提供程序,而答案是odp.net

2 个答案:

答案 0 :(得分:2)

您的函数有两个输入参数,因此您的调用还必须定义两个输入参数加返回参数。方法Add(OracleParameter)是可能的,但是很多余。

应该是这样的:

comm = new OracleCommand();
comm.CommandType = CommandType.StoredProcedure;
comm.Connection = conn;

comm.CommandText = "log_in";
comm.Parameters.Add("x", OracleDbType.Varchar2, ParameterDirection.Input).Value = textBox1.Text; 
   // As far as I remember "ParameterDirection.Input" is the default, so you may skip it
comm.Parameters.Add("y", OracleDbType.Varchar2, ParameterDirection.Input).Value = textBox2.Text;
comm.Parameters.Add("ret", OracleDbType.Byte, ParameterDirection.ReturnValue);
comm.Parameters["ret"].DbType = DbType.Byte;
comm.ExecuteNonQuery();

String returnValue = comm.Parameters["ret"].Value.ToString();

实际上,我从未使用过CommandType.StoredProcedure。如果上面的代码不起作用,请尝试以下代码:

comm.CommandType = CommandType.Text;
comm.CommandText = "BEGIN :ret := log_in(:x, :y); END;";

答案 1 :(得分:1)

嗨,我在使用 StoredProcedure 时遇到了一些问题。并最终让它工作。

comm = new OracleCommand();
comm.CommandType = CommandType.StoredProcedure;
comm.Connection = conn;

comm.CommandText = "log_in";
// Important is to add returnValue as described bellow
OracleParameter retval = new OracleParameter("ret", OracleDbType.Varchar2 , 20);
retval.Direction = ParameterDirection.ReturnValue;
comm.Parameters.Add(retval);
comm.Parameters.Add("x", OracleDbType.Varchar2, ParameterDirection.Input).Value = textBox1.Text; 
comm.Parameters.Add("y", OracleDbType.Varchar2, ParameterDirection.Input).Value = textBox2.Text;
comm.ExecuteNonQuery();

String returnValue = comm.Parameters["ret"].Value.ToString();