检验是否重复的存储过程函数(SQL Server)

来源:互联网 发布:360 浏览器 mac 编辑:程序博客网 时间:2024/05/22 05:19
// 检验是否重复的存储过程函数(SQL Server)
    public bool GetVerify(String strProcedure, String strIdName, String strVerifyName, String strIdValue, String strVerifyValue, bool bIsAddNew)
    {
        // 数据库连接参数(对客户端应用程序配置文件的访问)
        string strConn = @ConfigurationManager.ConnectionStrings["MyConnectionString"].ConnectionString;
        // 创建连接数据库的一个打开连接
        SqlConnection MyConn = new SqlConnection(strConn);
        try // 正常运行
        {
            // 要对数据库执行的一个SQL语句或存储过程
            SqlCommand MyComm = new SqlCommand(strProcedure, MyConn);
            // 采用存储过程方式
            MyComm.CommandType = CommandType.StoredProcedure;
            // 清除所有实例
            MyComm.Parameters.Clear();
            ////////////////////////////////////////////////////////////////////////////////////////////////
            // ID
            MyComm.Parameters.Add("@" + strIdName, SqlDbType.Int).Value = strIdValue;
            // 判断
            MyComm.Parameters.Add("@" + strVerifyName, SqlDbType.Text).Value = strVerifyValue;
            // 新增判断
            MyComm.Parameters.Add("@bIsAddNew", SqlDbType.Bit).Value = bIsAddNew;
            // 使用 ConnectionString 所指定的属性设置打开数据库连接
            MyConn.Open();
            // 提供一种从数据库读取只进的行流的一种方式
            SqlDataReader MyReader = MyComm.ExecuteReader();
            // 读取数据,判断是否有数据
            if (MyReader.HasRows)
            {
                // 读取数据
                MyReader.Read();
                // 判断
                if (MyReader.GetString(MyReader.GetOrdinal("GetVerify")).ToString() == "False")
                {
                    if ((MyReader != null) & (MyReader.IsClosed!=true))
                    {
                        // 关闭
                        MyReader.Close();
                    }
                    // 返回失败
                    return false;
                }
                else
                {
                    if ((MyReader != null) & (MyReader.IsClosed!=true))
                    {
                        // 关闭
                        MyReader.Close();
                    }
                    // 返回成功
                    return true;
                }
            }
            else
            {
                Console.Write("<script language=JavaScript>");
                Console.Write("alert('系统提示:数据读取失败或网络忙,请稍后再试!');");
                Console.Write("</script>");
                if ((MyReader != null) & (MyReader.IsClosed!=true))
                {
                    // 关闭
                    MyReader.Close();
                }
                // 判断数据库连接
                if (MyConn.State == ConnectionState.Open)
                {
                    // 关闭数据库连接
                    MyConn.Close();
                }
                // 返回失败
                return false;
            }
        }
        catch (SqlException) // 数据库操作异常处理
        {
            Console.Write("<script language=JavaScript>");
            Console.Write("alert('系统提示:当前数据库操作失败或网络忙,请稍后再试!');");
            Console.Write("</script>");           
            if (MyConn.State == ConnectionState.Open)
            {
                // 关闭数据库连接
                MyConn.Close();
            }
            // 返回失败
            return false;
        }
        catch (Exception Exp) // 异常处理
        {
            // 异常处理
            Console.Write("<script language=JavaScript>");
            Console.Write("alert('" + Exp.Message.ToString() + "');");
            Console.Write("</script>");           
            if (MyConn.State == ConnectionState.Open)
            {
                // 关闭数据库连接
                MyConn.Close();
            }
            // 返回失败
            return false;
        }
     finally // 执行完毕清除在try块中分配的任何资源
        {
            if (MyConn.State == ConnectionState.Open)
            {
                // 关闭数据库连接
                MyConn.Close();
            }
        }
    }