WebServices(C#)--返回查询数据集(DataSet)

该博客介绍了一个使用C#实现的WebMethod,该方法接收SQL查询字符串,通过SqlConnection连接数据库,执行查询并返回DataSet。在处理过程中,包含了异常处理和数据库连接的打开与关闭,确保了数据的正确获取和资源的释放。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 [WebMethod(Description = "功能:返回查询数据集 | 参数:SQL查询 | 返回:数据集 | 返回类型:DataSet")]
public DataSet GetDataSet(string strSQL)
{
    // 数据库连接参数(对客户端应用程序配置文件的访问)
    string strConn = @ConfigurationManager.ConnectionStrings["MyConnectionString"].ConnectionString;
    // 创建连接数据库的一个打开连接
    // 设置打开数据库连接
    SqlConnection MyConn = new SqlConnection(strConn);
    try // 正常运行
    {
        string MySQL = @strSQL.Trim().ToString();
        // 使用 ConnectionString 所指定的属性设置打开数据库连接
        MyConn.Open();
        // 要对数据库执行的一个SQL语句或存储过程
        SqlCommand MyComm = new SqlCommand(MySQL, MyConn);
        // 一组数据命令和一个数据库连接,用于填充 DataSet 和更新数据源
        SqlDataAdapter MyAdapter = new SqlDataAdapter();
        // 数据在内存中的缓存
        DataSet MyDataSet = new DataSet();
        // 进行数据库查询
        MyAdapter.SelectCommand = new SqlCommand(strSQL, MyConn);
        // 在 DataSet 中添加或刷新行以匹配数据源中的行
        MyAdapter.Fill(MyDataSet);
        // 返回 DataSet
        return MyDataSet;
    }
    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();
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值