分类
标签
.NET 9008 adb android apt asp.net ASP.NET Core audio bug C c++ C++ chrome cmd csharp CSharp css css3 debian debug dotnet dotnet Framework dpkg GDI&GDI+ gdi&gdi+ golang graphics html html5 http java javascript json kali linux linux mci microsoft minimap MSBuild mysql OpenCV PInvoke powershell python QQ rust shell speex sql tutorial ubuntu ui unity vb.net visual studio Visual Studio web Web win32 winapi windows winform WinForm wpf WPF xaml xfce 列表 刷机 前端 加密 反射 反编译 可视化 图像处理 多线程 字符串 安卓 实例 局域网 幻影坦克 库 开发语言 异步 微信 手册 手机 接口 摘要 救砖 数字签名 数字证书 数字音频 数据库 桌面程序 游戏 游戏引擎 源码 爬虫 玩游戏 电脑硬件 笔记 算法 类库 线性代数 编程语言 网络 脚本语言 计算机图形学 计算机基础 设计模式 语音编解码 运维 进制 面向对象编程 音频 音频编码解码
209 字
1 分钟
[踩坑记录] ASP.NET Core System.Data.SqlTypes.SqlNullValueException: 数据为空。不能对空值调用此方法
问题是出在这里的:
SoftwareInfo result = new SoftwareInfo(
reader.GetString(1), // reader 是 MySqlDataReader 实例
reader.GetString(7))
{
ID = reader.GetInt32(0),
Label = reader.GetString(2),
Coder = reader.GetString(3),
DownloadCount = reader.GetInt32(4),
Stars = reader.GetFloat(5),
Introduction = reader.GetString(6)
};
return result;
解决方案:
第一种: 添加 Null 检查, 在调用 GetString, GetInt32, GetFloat 这类包含具体的类型转换的函数前, 先调用 IsDBNull 检查这条数据是不是 Null.
SoftwareInfo currentInfo = new SoftwareInfo(
reader.GetString(1),
reader.GetString(7))
{
ID = reader.GetInt32(0),
Label = reader.IsDBNull(2) ? null : reader.GetString(2),
Coder = reader.IsDBNull(3) ? null : reader.GetString(3),
DownloadCount = reader.IsDBNull(4) ? 0 : reader.GetInt32(4),
Stars = reader.IsDBNull(5) ? 0 : reader.IsDBNull(5) ? 0 : reader.GetFloat(5),
Introduction = reader.IsDBNull(6) ? null : reader.GetString(6)
};
return currentInfo;
第二种: 直接指定数据库的字段不可为 Null, 从根本上杜绝空值
alter table tablename modify columnname not null;
原因:
如果数据是 Null, 就无法调用包含具体类型的方法, 因为它们内部涉及到类型转换.
[踩坑记录] ASP.NET Core System.Data.SqlTypes.SqlNullValueException: 数据为空。不能对空值调用此方法
https://slimenull.com/posts/20210129050708/