我是c#中使用反射的新手。如有任何帮助,不胜感激。
PropertyInfo。GetValue(obj, null)给我一个对象值。
如果列的值在数据库中为null,我得到一个null异常:
System.Reflection。TargetInvocationException:异常已被调用的目标抛出。Microsoft.SqlServer.Dts.Pipeline.ColumnIsNullException:列的值为空
如何处理这种情况?我应该循环遍历所有的列,并保留为空值的列
您可以直接检查'Null'
if(propInfo.GetValue(this, null) != null) {
}
该属性的getter抛出异常。它试图告诉你属性没有值
您应该能够检查PropertyName_IsNull
(其中PropertyName是属性的名称),以检查该属性是否为空。如果为空,适当处理,否则使用您已经编写的代码。
为每个选定的输入列设置
_IsNull属性。此属性也是只读或读/写,具体取决于为列指定的使用类型。
PropertyInfo.GetValue(obj, null)
正在对象obj
上执行属性get方法。异常在get方法中被抛出。您需要查看正在调用的属性get方法,并确定何时/为什么会抛出异常。