请问赋空值为什么不成功

michaelmodna 2009-12-30 12:21:43
Dim dsService As New clsProService.MppsServiceSet()
Dim drService As MppsServiceSet.MppsServiceSetRow

with drService
.name = system.convert.dbnull
end with


我在dsservice中定义的name列是string型的,当运行上述位置时,出错了,信息为:

"System.InvalidCastException: Cast from type 'DBNull' to type 'String' is not valid.
at Microsoft.VisualBasic.CompilerServices.StringType.FromObject(Object Value)
at VPOSGateway.IBank1001.ModifyPersonDNA(Byte[] reqbuffer)

我尝试换成

.name= dbnull.value 也不行,请问如何给 null 值 呢 ,谢谢!
...全文
287 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
nice3k 2010-01-01
  • 打赏
  • 举报
回复
nice3k 2010-01-01
  • 打赏
  • 举报
回复
学习了
lwd203 2009-12-31
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 michaelmodna 的回复:]
引用 6 楼 lsh2216024 的回复:
界面上用string。empty,存储时用null嘛


只能用此方法了吗,为什么dataset里面定义的 string型不能直接存null呢?
[/Quote]
dataset里面定义的 string 和 NUll不是一种类型,当然不能赋值
michaelmodna 2009-12-31
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 cfesc9 的回复:]
引用 2 楼 knightwayne 的回复:
with drService
  .name = ""
end with


我也认为是这样,你的name是一个string类型,即可赋个空串给它。
[/Quote]

试了好几个方法,发现只能用这种了,就是比较麻烦一些,先给空,然后在下一次commit前做个判断转换,在 sqlcommand那里能给null

Dim cmd As SqlClient.SqlCommand
with cmd
'服务卡号
If objMppsServiceSet._dcdnum = String.Empty Then
.Parameters.Add("@cpa_dcdnum_sc", SqlDbType.VarChar).Value = DBNull.Value
Else
.Parameters.Add("@cpa_dcdnum_sc", SqlDbType.VarChar).Value = objMppsServiceSet._dcdnum
End If
end with

michaelmodna 2009-12-31
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 asdfy 的回复:]
Nothing试试,如果不想存那就不赋值不行吗?
[/Quote]

nothing不行的,我们试过了,谢谢
knightwayne 2009-12-30
  • 打赏
  • 举报
回复
with drService
.name = ""
end with
SQL77 2009-12-30
  • 打赏
  • 举报
回复
Cast from type 'DBNull' to type 'String' is not valid
转换出错呀
直接NULL不行吧,语法不懂
古今多少事 2009-12-30
  • 打赏
  • 举报
回复
Nothing试试,如果不想存那就不赋值不行吗?
michaelmodna 2009-12-30
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 lsh2216024 的回复:]
界面上用string。empty,存储时用null嘛
[/Quote]

只能用此方法了吗,为什么dataset里面定义的 string型不能直接存null呢?
cfesc9 2009-12-30
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 knightwayne 的回复:]
with drService
  .name = ""
end with

[/Quote]
我也认为是这样,你的name是一个string类型,即可赋个空串给它。
lsh2216024 2009-12-30
  • 打赏
  • 举报
回复
界面上用string。empty,存储时用null嘛
飞驴 2009-12-30
  • 打赏
  • 举报
回复
等于空不行嘛。name=“”
michaelmodna 2009-12-30
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 knightwayne 的回复:]
with drService
  .name = ""
end with

[/Quote]

兄弟,不行阿,我现用的 .name=string.empty,但库表中不能存值阿,库表中只能存null数据,不能为空字串的。
Love_baba_mama 2009-12-30
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 knightwayne 的回复:]
with drService
  .name = ""
end with
[/Quote]
我认为是这样

16,718

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧