读书人

数据库超时,该怎么解决

发布时间: 2011-12-31 23:50:30 作者: rapoo

数据库超时
连接正常
当处理
oAdapter = New SqlDataAdapter(oCmd)
oAdapter.Fill(oDataSetSQL.ReturnedDataSet)

执行fill的时候,显示数据库超时

本地服务器没事


[解决办法]
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];


}

读书人网 >VB Dotnet

热点推荐