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];


        }

你可能感兴趣的:(timeout)