我正在为我们的应用程序创建一个通用的错误处理/日志记录类。目的是记录异常信息,有关类和函数(以及参数)的信息以及有关System.Data.SqlClient.SqlCommand
对象的信息(如果相关)。
我希望能够处理SqlCommands
,TableAdaptors
和SqlDataAdaptors
的传递。
我是使用反射技术的新手,我知道可以做到这一点,但我不确定该如何做。请指教。
最佳答案
这是你在说什么吗?
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)。