DbDataAdapter.Fill() 在执行参数时非常慢!
我有一个内部有 2 个参数的查询,当我将这些参数硬编码到查询中时,执行需要 1 秒(在 470k 表行中,仅返回 20 行)。
我在这里发现了许多类似的帖子,我尝试了所有这些解决方案(设置 arithabort、选项重新编译、选项优化……),但没有成功。
我只是执行查询(sql server 2008)而不是存储过程,所以使用 arithabort 的查询是这样的:
string strSql = @"set ARITHABORT ON; select TOP 20 ....
我也尝试在同一个事务中调用 set arithabort 但首先执行该查询..
我不知道我是否做错了什么,但感觉是当我在 ado.net 上定义参数时,ado.net 在 ado.net 中执行了一个非常糟糕的执行计划。
由于这个错误的选择,SSMS 中的执行时间是 1 秒(缓存后),但在 asp 中是 9 秒!
查询是这样的:
strSQL @=" select *
from Table1 where Name like @name";
接着:
DbProviderFactory factory = DbProviderFactories.GetFactory(mProvider); DbCommand dbcmd = factory.CreateCommand(); if (CommandTimeout != null) dbcmd.CommandTimeout = CommandTimeout.Value; if(this.transaccion != null) dbcmd.Transaction = this.transaccion; dbcmd.Connection = dbc; dbcmd.CommandText = strSQL; if (parametros != null) dbcmd.Parameters.AddRange(parametros); DbDataAdapter dbda = factory.CreateDataAdapter(); dbda.SelectCommand = dbcmd; DataTable dt = new DataTable(); dbda.Fill(dt); return dt;
编辑 14/01/2013 (18:44)
我不再从 DbProviderFactory 检索连接,而是直接使用 SqlConnection 和 SqlCommand。我知道 DbCommand 和 DbProvider 是一个基类......但我认为那里还有更多......因为性能急剧提高了 300%!
这不是填充方法,因为我已经尝试过之前显示的代码..
无论如何,我不知道为什么但是使用 SqlConnection 更快!任何想法?也许之前没有制定过那么糟糕的执行计划?
SqlCommand objCmd = new SqlCommand(strSQL, sqlConn); if (CommandTimeout != null) objCmd.CommandTimeout = CommandTimeout.Value; if (this.transaccion != null) objCmd.Transaction = SQLtransaccion; if (parametros != null) objCmd.Parameters.AddRange(parametros); DbDataReader dbReader = objCmd.ExecuteReader(); DataTable dt = new DataTable(); dt.Load(dbReader); dbReader.Close(); return dt;
任何帮助将不胜感激,
谢谢,