我正在做这样的事情:
SqlParameter param = new SqlParameter("@Param", 0) { SqlDbType = SqlDbType.Int };
private void TestParam(SqlParameter param) {
string test = param.Value.ToString(); // Getting NullReferenceException here
}
但是当我这样说时,我不再遇到异常:
SqlParameter param = new SqlParameter("@Param", SqlDbType.Int) { Value = 0 };
private void TestParam(SqlParameter param) {
string test = param.Value.ToString(); // Everything OK
}
谁能告诉我为什么 SqlParameter 假设 0 与 null 相同?
编辑: MSDN 在这里解释:SqlParameter Constructor