繁体   English   中英

从 C# 内部调用 PL_SQL 函数

[英]Calling a PL_SQL function from inside c#

我创建了一个 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;

注意-我的数据源是 oracle 的 .NET 框架数据提供程序,答案是 odp.net

您的函数有两个输入参数,因此您的调用还必须定义两个输入参数和返回参数。 方法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;";

您好,我在使用 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();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM