在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
在使用 DataTable 的时候,经常会出现字段值是 System.DBNull 的情况,如果不做判断就会抛出一下异常提示: // 如果没有输入长度限制值或长度值解析失败,则默认不做限制,长度判断值设置为整数最大值 int length = 0; length = Int32.TryParse(((item["LengthConstraint"])) ? "" : item["LengthConstraint"].ToString(), out length) ? length : Int32.MaxValue; 注意:System.DBNull 和 null 是不一样的,两者用 == 或者 equals 判断返回的是 false。 如果是这样,则将字段值追加到标签中的字符串输出。 参考链接:https://docs.microsoft.com/zh-cn/dotnet/api/system.dbnull.value?view=netcore-3.1 private void OutputLabels(DataTable dt) { string label; // Iterate rows of table foreach (DataRow row in dt.Rows) { int labelLen; label = String.Empty; label += AddFieldValue(label, row, "Title"); label += AddFieldValue(label, row, "FirstName"); label += AddFieldValue(label, row, "MiddleInitial"); label += AddFieldValue(label, row, "LastName"); label += AddFieldValue(label, row, "Suffix"); label += "\n"; label += AddFieldValue(label, row, "Address1"); label += AddFieldValue(label, row, "AptNo"); label += "\n"; labelLen = label.Length; label += AddFieldValue(label, row, "Address2"); if (label.Length != labelLen) label += "\n"; label += AddFieldValue(label, row, "City"); label += AddFieldValue(label, row, "State"); label += AddFieldValue(label, row, "Zip"); Console.WriteLine(label); Console.WriteLine(); } } private string AddFieldValue(string label, DataRow row, string fieldName) { if (! DBNull.Value.Equals(row[fieldName])) return (string) row[fieldName] + " "; else return String.Empty; }
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论