返回数据库数据的存储过程函数(2个参数)(SQL Server)
2007-05-20 19:01
525 查看
// 返回数据库数据的存储过程函数(2个参数)(SQL Server)
public SqlDataReader GetPrViewReader(String strProcedure, String strLookUp, String strNewLookUp, String strBeginDate, String strEndDate)
{
// 数据库连接参数(对客户端应用程序配置文件的访问)
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();
////////////////////////////////////////////////////////////////////////////////////////////////
// Lookup
MyComm.Parameters.Add("@LookUp", SqlDbType.Text).Value = strLookUp;
// NewLookUp
MyComm.Parameters.Add("@NewLookUp", SqlDbType.Text).Value = strNewLookUp;
// BeginDate
MyComm.Parameters.Add("@BeginDate", SqlDbType.Text).Value = strBeginDate;
// BeginDate
MyComm.Parameters.Add("@EndDate", SqlDbType.Text).Value = strEndDate;
// 使用 ConnectionString 所指定的属性设置打开数据库连接
MyConn.Open();
// 提供一种从数据库读取只进的行流的一种方式
SqlDataReader MyReader = MyComm.ExecuteReader();
// 读取数据,判断是否有数据
if (MyReader.HasRows)
{
// 返回成功
return MyReader;
}
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 null;
}
}
catch (SqlException) // 数据库操作异常处理
{
Console.Write("<script language=JavaScript>");
Console.Write("alert('系统提示:当前数据库操作失败或网络忙,请稍后再试!');");
Console.Write("</script>");
if (MyConn.State == ConnectionState.Open)
{
// 关闭数据库连接
MyConn.Close();
}
// 返回失败
return null;
}
catch // 异常处理
{
if (MyConn.State == ConnectionState.Open)
{
// 关闭数据库连接
MyConn.Close();
}
// 返回失败
return null;
}
finally // 执行完毕清除在try块中分配的任何资源
{
if (MyConn.State == ConnectionState.Open)
{
// 关闭数据库连接
//MyConn.Close();
}
}
}
public SqlDataReader GetPrViewReader(String strProcedure, String strLookUp, String strNewLookUp, String strBeginDate, String strEndDate)
{
// 数据库连接参数(对客户端应用程序配置文件的访问)
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();
////////////////////////////////////////////////////////////////////////////////////////////////
// Lookup
MyComm.Parameters.Add("@LookUp", SqlDbType.Text).Value = strLookUp;
// NewLookUp
MyComm.Parameters.Add("@NewLookUp", SqlDbType.Text).Value = strNewLookUp;
// BeginDate
MyComm.Parameters.Add("@BeginDate", SqlDbType.Text).Value = strBeginDate;
// BeginDate
MyComm.Parameters.Add("@EndDate", SqlDbType.Text).Value = strEndDate;
// 使用 ConnectionString 所指定的属性设置打开数据库连接
MyConn.Open();
// 提供一种从数据库读取只进的行流的一种方式
SqlDataReader MyReader = MyComm.ExecuteReader();
// 读取数据,判断是否有数据
if (MyReader.HasRows)
{
// 返回成功
return MyReader;
}
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 null;
}
}
catch (SqlException) // 数据库操作异常处理
{
Console.Write("<script language=JavaScript>");
Console.Write("alert('系统提示:当前数据库操作失败或网络忙,请稍后再试!');");
Console.Write("</script>");
if (MyConn.State == ConnectionState.Open)
{
// 关闭数据库连接
MyConn.Close();
}
// 返回失败
return null;
}
catch // 异常处理
{
if (MyConn.State == ConnectionState.Open)
{
// 关闭数据库连接
MyConn.Close();
}
// 返回失败
return null;
}
finally // 执行完毕清除在try块中分配的任何资源
{
if (MyConn.State == ConnectionState.Open)
{
// 关闭数据库连接
//MyConn.Close();
}
}
}
相关文章推荐
- 返回数据库数据的存储过程函数(5个参数)(SQL Server)
- 返回数据库数据的存储过程函数(4个参数)(SQL Server)
- 返回数据库数据的存储过程函数(3个参数)(SQL Server)
- 返回数据库数据的存储过程函数(1个参数)(SQL Server)
- 返回数据库数据的存储过程函数(SQL Server)
- 返回数据库数据DataSet函数(SQL Server)
- 返回数据库数据总数的过程(1个参数)
- sql server里获取向数据库插入数据后返回新插入行的主键
- C#中返回最后一次插入数据的id(数据库:sql server)
- SQL Server 2000的数据库所有数据参数
- VB.NET、EXCEL调用SQL Server带参数的存储过程并返回数据集
- mybatis3.2.3向数据库sql server 2005插入数据(insert)时返回主键值为空(null)或者1,
- 在C#应用程序中,利用表值参数过滤重复,批量向数据库导入数据,并且返回重复数据
- 在 DataGrid 控件中显示 SQL Server 数据库中的数据
- 22、SQL Server 数据修改之返回修改的数据
- [读取文件数据],open()的返回类型和【list.append(),造成显性写入\n】。方法参数的缺省带来的影响?
- Sql server 日记 (远程连接数据库库查询数据库)
- SQLSERVER 免费对比数据库结构和数据的工具支持:SQL Server 2012, SQL Server 2008 and SQL Server 2005
- 搜集的很不错的数据访问类(sql server 数据库)
- SQL Server 7.0数据库的六种数据移动方法