首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >处理DBNull数据

处理DBNull数据
EN

Stack Overflow用户
提问于 2015-06-18 20:56:46
回答 3查看 58关注 0票数 0

我将一个datarow对象的值赋给另一个datarow对象。例如:

代码语言:javascript
复制
newAddress.AddrId     = frenchAddress.AddrId
newAddress.AddrLn1    = frenchAddress.AddrLn1
newAddress.AddrLn2    = frenchAddress.AddrLn2
newAddress.AddrLn3    = frenchAddress.AddrLn3
newAddress.AddrCityNm = frenchAddress.AddrCityNm
newAddress.CntryId    = frenchAddress.CntryId
newAddress.ProvId     = frenchAddress.ProvId

frenchAddress中的一些值可能为空,因此我最终得到了一个异常,因为我将DBNull的值赋给了newAddress。处理DBNull的最好和最干净的方法是什么?有DBNull的地方可以直接插入NULL

使用VB.Net。

EN

回答 3

Stack Overflow用户

发布于 2015-06-18 21:02:03

由于这是一个类型化的DataRow(因此是一个具有命名属性的自动生成的类型),因此已经有了用于此目的的方法:

代码语言:javascript
复制
If frenchAddress.IsAddrCityNmNull Then
    newAddress.SetAddrCityNmNull()
Else
    newAddress.AddrCityNm = frenchAddress.AddrCityNm
End If 

如果它不是类型化的而是标准的DataRow,那么您可以使用支持可空类型的SetField方法,并且还应该处理这种情况:

代码语言:javascript
复制
newAddress.SetField("ColumnName", frenchAddress.Field(Of String)("ColumnName"))
票数 1
EN

Stack Overflow用户

发布于 2015-06-18 21:04:36

您可以将IsDbNull函数与If语句一起使用,例如:

代码语言:javascript
复制
newAddress.AddrLn1 = If (IsDbNull(frenchAddress.AddrLn1), String.Empty, frenchAddress.AddrLine1)
票数 1
EN

Stack Overflow用户

发布于 2015-06-19 02:25:43

这最终是我使用的解决方案,有点混合了上面两个答案。它似乎工作得不错:

代码语言:javascript
复制
newAddress.AddrLn1 = If(frenchAddress.IsAddrLn1Null = True, Nothing, frenchAddress.AddrLn1)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30915987

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档