asp.netmvc中将数据库读取到list<T>并显示返回null值的一些列已经有值
创始人
2024-09-19 09:30:17
0

出现这个问题的可能原因是数据表中有一些列的值为空。在C#中,当数据库中的空值(null)被读入List时,它们将被转换为C#中的默认值。这意味着除非你使用Nullable类型,否则空值将被转换为T类型的默认值。

为了解决这个问题,你需要在模型类中使用Nullable类型。你可以在类中为可空值类型的属性加上"?"号,告诉C#编译器这些属性可以为null。

以下是示例代码:

模型类:

public class MyModel { public int ID { get; set; } public string Name { get; set; } public int? Age { get; set; } //使用Nullable类型 }

控制器:

public ActionResult Index() { List modelList = new List(); //模拟获取数据 DataTable dt = GetDataFromDB(); foreach (DataRow dr in dt.Rows) { MyModel model = new MyModel(); model.ID = Convert.ToInt32(dr["ID"]); model.Name = dr["Name"].ToString(); model.Age = dr["Age"] == DBNull.Value ? null : (int?)Convert.ToInt32(dr["Age"]); modelList.Add(model); } return View(modelList); }

视图:

@model List

@foreach (var item in Model) {

@item.ID, @item.Name, @item.Age

}

在上述示例中,我们通过检查DataRow对象中的值是否为DBNull.Value来处理空值,并将Nullable类型的值设置为null。这样,在将数据绑定到视图时,空值就不会被转换为默认值了。

相关内容

热门资讯

第8分钟插件!海盗来了辅助哪个... 第8分钟插件!海盗来了辅助哪个好,微信小程序游戏辅助器(本来是真的辅助神器)-哔哩哔哩1、下载好微信...
第九分钟学习!wepoker辅... 第九分钟学习!wepoker辅助器如何使用(透视)果然存在有辅助开挂(哔哩哔哩)wepoker辅助器...
八分钟辅助!中至二人辅助器,四... 八分钟辅助!中至二人辅助器,四川途游小程序辅助(本来有挂辅助修改器)-哔哩哔哩1、进入到四川途游小程...
第7分钟大纲!wpk有那种辅助... 第7分钟大纲!wpk有那种辅助吗(透视)原来是真的有辅助神器(哔哩哔哩)进入游戏-大厅左侧-新手福利...
3分钟辅助!微信卡农辅助,新天... 3分钟辅助!微信卡农辅助,新天道怎么看底牌(原来真的是有辅助软件)-哔哩哔哩1、金币登录送、破产送、...
第一分钟指南!德州机器人代打脚... 第一分钟指南!德州机器人代打脚本(透视)其实是真的有辅助下载(哔哩哔哩)1、用户打开应用后不用登录就...
四分钟插件!传送屋app辅助,... 四分钟插件!传送屋app辅助,欢乐联盟辅助软件(一贯有挂辅助工具)-哔哩哔哩1、首先打开欢乐联盟辅助...
六分钟法门!wepoker开辅... 六分钟法门!wepoker开辅助能查到吗(透视)其实是有辅助辅助(哔哩哔哩)wepoker开辅助能查...
3分钟脚本!新九哥辅助app,... 3分钟脚本!新九哥辅助app,蜀山四川辅助(一贯是真的辅助辅助)-哔哩哔哩1、操作简单,无需新九哥辅...
第一分钟窍要!hhpoker真... 第一分钟窍要!hhpoker真能买到挂吗(透视)确实存在有辅助辅助(哔哩哔哩)1、首先打开hhpok...