我正在为我们的应用程序创建一个通用的错误处理/日志记录类。目的是记录异常信息,有关类和函数(以及参数)的信息以及有关System.Data.SqlClient.SqlCommand对象的信息(如果相关)。

我希望能够处理SqlCommandsTableAdaptorsSqlDataAdaptors的传递。

我是使用反射技术的新手,我知道可以做到这一点,但我不确定该如何做。请指教。

最佳答案

这是你在说什么吗?

SqlDataAdapter da = new SqlDataAdapter();
var cmd1 = ((IDbDataAdapter)da).DeleteCommand;
var cmd2 = ((IDbDataAdapter)da).UpdateCommand;
var cmd3 = ((IDbDataAdapter)da).SelectCommand;
var cmd4 = ((IDbDataAdapter)da).InsertCommand;

SqlDataAdapter实现IDbDataAdapter,它具有所有CRUD命令的getter/setter方法。 SqlDataAdapter显式实现这些功能,因此除非您首先将其强制转换为接口(interface),否则它们不会显示在类的签名中。无需反射(reflection)。

10-07 20:18