Каков минимальный объем кода, который я могу написать, чтобы получить один обратный вызов из EF 4.1, который обеспечивает следующее:
-
OnSQLExecuted(DbCommand cmd, DateTime start, double durationMS, string stacktrace)
В настоящий момент мы используем неприятный хак, который, кажется, просачивается, мне интересно, как мы можем достичь этого обратного вызова с минимальным воздействием на приложение.
Мы можем подключить это в Mini Profiler от взломать - в основном мы изменили Database.DefaultConnectionFactory
, однако сбрасывание по умолчанию factory означает, что у вас не может быть двух профилирующих заводов, идущих одновременно. Таким образом, мы пошли более агрессивным путем.
Используемая техника довольно проста, вы реализуете: DbProviderFactory
, IDbConnectionFactory
, DbProviderServices
, DbConnection
, DbCommand
и DbDataReader
таким образом, чтобы они перехватывали вызовы и профиль.
До сих пор, просто... однако это становится беспорядочным, когда вы пытаетесь подключить это:
try
{
// ensure all the factories are loaded
DbProviderFactories.GetFactory("...");
}
catch (ArgumentException)
{
}
Type type = typeof(DbProviderFactories);
DataTable table;
// SUPER UGLY - Can this be done in another way?
object setOrTable = (type.GetField("_configTable", BindingFlags.NonPublic | BindingFlags.Static) ??
type.GetField("_providerTable", BindingFlags.NonPublic | BindingFlags.Static)).GetValue(null);
if (setOrTable is DataSet)
{
table = ((DataSet)setOrTable).Tables["DbProviderFactories"];
}
table = (DataTable)setOrTable;
foreach (DataRow row in table.Rows.Cast<DataRow>().ToList())
{
DbProviderFactory factory;
try
{
factory = DbProviderFactories.GetFactory(row);
}
catch (Exception)
{
continue;
}
var profType = typeof(MvcMiniProfiler.Data.EFProfiledDbProviderFactory<>).MakeGenericType(factory.GetType());
DataRow profiled = table.NewRow();
profiled["Name"] = row["Name"];
profiled["Description"] = row["Description"];
profiled["InvariantName"] = row["InvariantName"];
profiled["AssemblyQualifiedName"] = profType.AssemblyQualifiedName;
table.Rows.Remove(row);
table.Rows.Add(profiled);
}
Для последней версии EF необходимы некоторые рефлексивные взломы и полная бомба.
FileLoadException: The given assembly name or codebase was invalid. (Exception from HRESULT: 0x80131047)
Это было документировано как Frans и Ayende.
Как подключить мои профилирующие фабрики и семью прочным и элегантным способом?
Есть ли другой способ получить мой обратный вызов?