• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
洛客
追求完美的用户体验。
博客园    首页    新随笔    联系   管理    订阅  订阅

SQL Timeout 的问题之解决方法

一般来说返回DataSet的函数都是这么写
public DataSet getrs(string sql)
{
System.Data.SqlClient.SqlConnection = new SqlConnection();
System.Data.SqlClient.SqlDataAdapter comm=new SqlDataAdapter(sql,conn);
System.Data.DataSet ds=new DataSet();
comm.Fill(ds);
return ds;
}
其中 new SqlConnection()里面放连接数据库的字符串,
参数sql是查询语句,例如sql="select * from s_user"等等
但是如果这个查询时间比较长(因为表的里数据比较大,而且查询语句里还调用了函数),系统将会返回超时错误,不知道在哪里控制

在new SqlConnection()里面放连接数据库的字符串里面放Connect Timeout=300;是不对的,因为这是运算的时间,不是连接数据库的时间。

所以应该这么写返回DataSet的语句:
        public static DataTable ExecuteQuery(string sql,int cmdTimeout)
        {
                SqlCommand cmd;
                SqlConnection conn;
                conn = new SqlConnection();
                cmd = new SqlCommand(sql, conn);
                conn.Open();
                cmd.CommandTimeout = cmdTimeout;
                SqlDataAdapter Ada = new SqlDataAdapter();
                Ada.SelectCommand = cmd;

                DataSet ds = new DataSet();
                Ada.Fill(ds);
                conn.Close();
                conn.Dispose();
                cmd.Dispose();
                return ds.Tables[0];


        }

posted @ 2007-05-29 14:11  洛客  阅读(2694)  评论(1)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3