WCF中DBNull序列化的问题

摘自于网络!

在使用WCF传输数据的时候,有时候需要传输一些特殊点的类型,比如DBNull,这样Service就会抛错,因为Service不能识别该类型,不能正常将其序列化。
解决方法: (1)如是自定义DataContract,则需为Contract定义体加上KnownType Attribute,如下: [DataContract] [KnownType(typeof(System.DBNull))] (2)如是Service的方法(比如封装的ExecuteScalar在传输DBNull的时候就会出错),需为方法的Interface定义处加上ServiceKnownType Attribute,如下: [ServiceKnownType(typeof(System.DBNull))] object ExecuteScalar(。。。);
1.对DBNull的解释:  该类用于指示不存在某个已知值(通常在数据库应用程序中)。      在数据库应用程序中,空对象是字段的有效值。该类区分空值(空对象)和未初始化值(DBNull.Value 实例)。例如,表可以包含具有未初始化字段的记录。默认情况下,这些未初始化字段具有 DBNull 值。      该类还可以用于在 COM Interop 中区分 VT_NULL 变量(与空对象关联)和 VT_EMPTY 变量(与 DBNull.Value 实例关联)。      DBNull 从不等于任何值。      DBNull 是一个单独的类,这意味着该类只能存在一个实例。这个唯一的实例是 DBNull.Value。      访问 SQL 数据库的数据密集应用程序必须使用 System.Data.SqlTypes 类,这些类对空值具有内在支持。 
-----------------------------------------------------------------------------------------------------------------
   DBNull在DotNet是单独的一个类型,该类只能存在唯一的实例,DBNULL.Value,DBNull唯一作用是可以表示数据库中的字符串,数 字,或日期,为什么可以表示原因是DotNet储存这些数据的类(DataRow等)都是以 object 的形式来储存数据的。对于 DataRow , 它的 row[column] 返回的值永远不为 null , 要么就是具体的为column 的类型的值 。 要么就是 DBNull 。 所以 row[column].ToString() 这个写法永远不会在ToString那里发生NullReferenceException。DBNull 实现了 IConvertible 。但是,除了 ToString 是正常的外,其他的ToXXX都会抛出不能转换的错误。
2. Null
   null 关键字是表示不引用任何对象的空引用的文字值。null 是引用类型变量的默认值。那么也只有引用型的变量可以为NULL,如果 int i=null,的话,是不可以的,因为Int是值类型的。    "null" means the object reference is invalid in .NET, when you retrieve a NULL value from the Database, it is a valid value to .NET, and it is represented by System.DBNull.Value    null用于判断Reference invalidate
3.""和String.Empty
这两个都是表示空字符串,其中有一个重点是string str1="" 和 string str2=null 的区别,这样定义后,str1是一个空字符串,空字符串是一个特殊的字符串,只不过这个字符串的值为空,在内存中是有准确的指向的,string str2=null,这样定义后,只是定义了一个string 类的引用,str2并没有指向任何地方,在使用前如果不实例化的话,都将报错。
4.Convert.IsDBNull()
   Convert.IsDBNull()返回有关指定对象是否为 DBNull 类型的指示,即是用来判断对象是否为DBNULL的。其返回值是True或Flase。
DBNull在DotNet是单独的一个类型 System.DBNull 。它只有一个值 DBNull.Value 。DBNull 直接继承 Object ,所以 DBNull 不是 string , 不是 int , 也不是 DateTime 。。。
但是为什么 DBNull 可以表示数据库中的字符串,数字,或日期呢?原因是DotNet储存这些数据的类(DataRow等)都是以 object 的形式来储存数据的。
对于 DataRow , 它的 row[column] 返回的值永远不为 null , 要么就是具体的为column 的类型的值。要么就是 DBNull 。 所以 row[column].ToString() 这个写法永远不会在ToString那里发生NullReferenceException。
DBNull 实现了 IConvertible 。 但是,除了 ToString 是正常的外,其他的ToXXX都会抛出不能转换的错误。
在 IDbCommand(OleDbCommand,SqlCommand...) 的ExecuteScalar的返回值中,情况可以这样分析:
select 1 这样返回的object是 1 select null 这样返回的是DBNull.Value select isnull(null,1) 返回的是 1 select top 0 id from table1 这样返回的值是null select isnull(id,0) from table1 where 1=0 返回的值是null
这里 ExecuteScalar 的规则就是,返回第一列,第一行的数据。如果第一列第一行不为空,那么ExecuteScalar就直接对应的DotNet的值。如果有第一行,但是第一 列为空,那么返回的是 DBNull 。如果一行都没有,那么ExecuteScalar就返回null
规则就是这样的。这里容易犯的一个错误是,把ExecuteScalar返回DBNull与null的情况混淆,例如:
string username=cmd.ExecuteScalar().ToString();
除非你认为cmd执行后,肯定至少有一行数据,否则这里就会出错。
又或者 select id from usertable where username=@name 这样的sql语句,如果找不到记录,那么ExecuteScalar则会返回null,所以千万不要
int userid=Convert.ToInt32(cmd.ExecuteScalar());
或者你会这样写 SQL 语句:select isnull(id,0) from usertable where username=@name
但是 int userid=Convert.ToInt32(cmd.ExecuteScalar()); 依然会出错,因为上面的语句不成立时,仍然是不返回任何行。
对于IDbDataParameter(OleDDbParameter,SqlParameter..)的Value,如果为null,则代表该参数没有指定,或者是代表DEFAULT。如果为DBNull.Value,则代表SQL中的NULL
所以,如果你要调用存储过程,里面有参数 @val nvarchar(20)="AABB" , 那么cmd.Parameters["@val"].Value=null 代表使用这个默认的 "AABB" 而cmd.Parameters["@val"].Value=DBNull.Value 代表使用NULL来传给 @val
你可以用Convert.IsDBNull来判断一个值是否DBNull。注意Convert.IsDBNull(null)是false

转载于:https://www.cnblogs.com/yalong_xiang/archive/2012/04/26/2470967.html

WCF中DBNull序列化的问题相关推荐

  1. WCF中因序列化问题引起的异常和错误。

    WCF中因序列化问题引起的异常和错误. 参考文章: (1)WCF中因序列化问题引起的异常和错误. (2)https://www.cnblogs.com/Ruiky/p/3713282.html 备忘一 ...

  2. WCF中的序列化[上篇]

    SOA 和Message Windows Communication Foundation (WCF) 是基于面向服务架构(Service Orientation Architecture--SOA) ...

  3. 我的WCF之旅(4):WCF中的序列化[下篇]

    ... ...续Part I XMLSerializer 提到XMLSerializer,我想绝大多数人都知道这是asmx采用的Serializer.首先我们还是来看一个例子,通过比较Managed ...

  4. WCF 中序列化自定义依赖属性类

    众所周知.NetFramework中存在着两种依赖属性,他们也分别集成着不同但名称相同的依赖对象: System.Windows.DependencyProperty:System.Windows.D ...

  5. Entity Framework在WCF中序列化的问题

    问题描述 如果你在WCF中用Entity Framework来获取数据并返回实体对象,那么对下面的错误一定不陌生. 接收对 http://localhost:5115/ReService.svc 的 ...

  6. Entity Framework在WCF中序列化的问题(转)

    问题描述 如果你在WCF中用Entity Framework来获取数据并返回实体对象,那么对下面的错误一定不陌生. 接收对 http://localhost:5115/ReService.svc 的 ...

  7. 十五天精通WCF——第十二天 说说wcf中的那几种序列化

    转自:https://www.cnblogs.com/huangxincheng/p/4660251.html 我们都知道wcf是由信道栈组成的,在我们传输的参数走到传输信道层之前,先需要经过序列化的 ...

  8. WCF中几个容易忽略的知识点

    近来看WCF相关资料 发现之前一些没太关注或者有些错误认识的知识点,有些也貌似不怎么常用.于是整理了这一则笔记. 1. WCF中的绑定. 可以通过绑定无参数构造函数实例化绑定,然后调用CreateBi ...

  9. WCF中的REST是什么

    基于SOAP消息格式的WCF之所以强大原因之一是因为SOAP消息头的高度扩展性.相应的WS-*协议很多都体现在消息头封装的信息上,包括诸如寻址,需要调用方法名,维护Session的信息等等-- SOA ...

  10. 在WCF中的异常处理方法

    在 WCF 中,客户端调用服务时,可能抛出的异常有以下三种类型. 1. 通讯异常.诸如网络错误,地址错误,服务器没有启动等等.这类异常多是 CommunicationException (或其具体继承 ...

最新文章

  1. catboost是什么?相对于xgboost以及lightgbm有什么优势?如何使用randomSearchCV和Catboost进行组合获取最优参数组合?
  2. Spring boot的put请求
  3. 走近NAP功能 全面了解Vista系统安全机制
  4. CSS之media query模板
  5. Oracle笔记:备份还原
  6. 网络管理员如何解放自己
  7. “疯狂猜成语”软件用户体验
  8. matplotlib Artist 教程
  9. 农业不一定靠规模赚钱
  10. VB LISTBOX
  11. CSS3之3D效果中的transform运用
  12. linux-LINUX试题
  13. RF工具ride使用
  14. testbench的简单例子和模板
  15. GD32F303串口ISP方式下载程序
  16. 新浪vip邮箱 服务器,新浪手机邮箱
  17. mongodb实现一主两从一个仲裁者
  18. 无线传感器网络期末复习知识点总结资料
  19. 李航《统计学习方法》第二版 实战(mnist为例)
  20. 【实战记录】使用阿里云的OSS云存储,上传与删除图片及遇到的问题

热门文章

  1. lanmp_wdcp_v2.4快速安装RPM包发布
  2. Linux新硬盘的使用
  3. SQL DATEADD函数
  4. stat,查看文件属性
  5. oracle的热备份和冷备份
  6. 独立线程池的作用及IO线程池
  7. UnityShader - 模拟动态光照特效
  8. 【MySQL必知必会】第十章 创建计算字段
  9. Yii1.0框架整合融云解析(一)
  10. 安装运行 rovio odometry