为了账号安全,请及时绑定邮箱和手机立即绑定

为什么new MySqlParameter("@val", 0).Value == null?

标签:
MySQL


前阵子同事写代码时发现MySQL数据表中经常被神奇的插入了空值,跟踪了半天代码,终于发现了问题所在:

DbParameter p = new MySqlParameter("@val", 0); 

Debug.Assert(p.Value == 0);  // 这里断言失败,p.Value实际是null 

分析了半天,没找到原因。猜想是MySql.Data把0当作null来处理了。心想,这不应该啊,完全没理由的事情啊,0在数据库里是个多么正常不过的值啊!心有不甘,于是把MySql.Data的源代码下载下来调试跟踪……然后发现了一个不得了的事情

MySqlParameter有几个构建函数,其中有两个是这么申明的

public MySqlParameter(string name, object value) { 

    // ...... 

 

public MySqlParameter(string name, MySqlDbType type) { 

    // ...... 

    // MySqlDbType是个枚举类型 

p = new MySqlParameter("@val", 0)实际是调用的是第二个构建函数,0被转换成MySqlDbType.Decimal传进去了,没有为其Value赋值,理所当然的p.Value为null。

那么,岂不是传入的整数都会被当作枚举……不然,如果传入的非0,调用的却又是第一个构建函数,1是被当作object来处理的!

然后我很疑惑,为什么0会被自动转成枚举类型来处理,而非0则会被当作object呢?为什么为什么为什么?谁能告诉我答案?

疑惑归疑惑,问题是解决了……

DbParameter p = new MySqlParameter("@val", (object) 0); 

Debug.Assert(p.Value == 0);  // 断言成功 

 

©著作权归作者所有:来自51CTO博客作者边城__的原创作品,如需转载,请注明出处,否则将追究法律责任

object 枚举类型转换C#


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消