正在执行Oracle过程

本文关键字:过程 Oracle 执行 | 更新日期: 2023-09-27 18:16:16

我将oracle数据库连接到visual studio,现在我正在尝试执行我在数据库中创建的过程。

我试过了:

           OracleCommand cmd = new OracleCommand("BEGIN ADD_USER('"+txtName.Text+"','"+txtName2.Text+"',"+txtID.Text+"); END;" );
            cmd.ExecuteNonQuery();

我的过程有3个参数:name, 2name, id。当我在sqldeveloper中使用这个命令时,它工作得很好,但是当我在我的项目中尝试它时,我会得到错误。

正在执行Oracle过程

using (OracleConnection cn = new OracleConnection("con string"))
{
    cn.Open();
    OracleCommand cmd = new OracleCommand("ADD_USER");
    cmd.CommandType = CommandType.StoredProcedure;
    cmd.Connection = cn;
    cmd.Parameters.Add("YourSPParamName1", OracleDbType.{YourFieldTypeInDB}).Value = txtName.Text;
    cmd.Parameters.Add("YourSPParamName2", OracleDbType.{YourFieldTypeInDB}).Value = txtName2.Text;
    cmd.Parameters.Add("YourSPParamName3", OracleDbType.{YourFieldTypeInDB}).Value = txtID.Text;
    cmd.ExecuteNonQuery();
}

我是这样做的:

        OracleConnectionStringBuilder sb = new OracleConnectionStringBuilder();
        sb.DataSource = "localhost";
        sb.UserID = "something";
        sb.Password = "pass";         
       OracleConnection conn = new OracleConnection(sb.ToString());
        conn.Open();
            OracleCommand cmd = new OracleCommand("ADD_USER");
            cmd.CommandType = CommandType.StoredProcedure;
            cmd.Connection = conn;
            cmd.Parameters.Add("NAME", OracleDbType.Varchar2).Value = txtName.Text;
            cmd.Parameters.Add("NAME2", OracleDbType.Varchar2).Value = txtName2.Text;
            cmd.Parameters.Add("ID", OracleDbType.Int32).Value = txtID.Text;
            cmd.ExecuteNonQuery();