为什么在这种情况下,无效合并运算符不起作用?

时间:2017-05-19 09:56:09

标签: c# .net

我正在尝试将记录提取到listarray中,如下所示:

List<Car> lst = new List<Car>();

string str = "select * from Inventory"; 

using(SqlCommand cmd = new SqlCommand(str,this.sqlcon))
{
    SqlDataReader rdr = cmd.ExecuteReader();

    while (rdr.Read())
    {
        lst.Add(new Car 
                    {
                        CarId = (int)rdr["CarId"],
                        Make = (string)(rdr["Make"] ?? ""),
                        Color= (string)(rdr["Color"] ?? ""),
                        PetName = (string)(rdr["PetName"] ?? "")

                    });
    }

    rdr.Close();
}

Make,color和petname可能具有空值,因此我使用了??运算符。我收到以下错误

  

无法转换system.dbnull类型的对象&#39;到&#39; system.string&#39;。

在这种情况下检查null的正确方法是什么?

2 个答案:

答案 0 :(得分:8)

DBNullnull不同,因此您无法使用??运算符。你必须单独处理这个案子。

替换:

Make = (string)(rdr["Make"] ?? ""),

使用:

Make =  (rdr["Make"] == System.DBNull.Value ? "" : (string)rdr["Make"]),

答案 1 :(得分:1)

SqlDataReader返回一个DBNull对象,它不是C#null - 它是一个表示数据库中NULL值的对象。

您有许多选项,并且创建一个处理方法可能最具可读性并且可以避免重复代码:

private static string GetStringOrEmpty(object dbValue){
    return dbValue == System.DBNull.Value ? string.Empty : (string)dbValue;
}

然后

Make = GetStringOrEmpty(rdr["Make"]),

或者看看Dapper这是一个非常小但功能强大的ORM,可以为你处理很多这些东西。