System.Nullable<T> int? 数据库中的int类型可以为空 在C# 中 的处理
2012-04-16 14:01
597 查看
System.Nullable<T> C#中怎么也引入了这样一个概念呢——“空属类型”,定义在值类型上,从此值类型摇身一变,也可以为空了,其实这个“空”也不是“真空”,怎么听起来这么矛盾,直观理解,“空Null”本身也是值的一种,可以被赋给值类型的变量了,实现这个想法和泛型有着不解之源: .空属类型允许一个值类型具有“空值”意义,从而方便很多场合的运算,如数据库的空字段。 .空属类型实际上是一个泛型类型System.Nullable<T>。 .空属类型的基础类型就是System.Nullable<T>的类型参数,其中T必须为值类型。 .空属类型如果值不为空,可以运用同样的基础类型所具有的运算,如+, - , *, / .空属类型的HasValue 属性用来判断类型是否为空,如果不为空,则可以通过Value属性来获取它的基础 类型的值。 1.声明方式: int? i;//相当于 System.Nullable<int> i;注意这里的问号修饰符 2.赋值: i = 2;//相当于i = new System.Nullable<int>(i) 3.简单类型和空属类型判等 int i = 11; int? x= 11; x.Equals(i) //结果如何呢其实为true 但想一想不对劲啊,如果取一下它们的类型: i.GetType() //int 而 x.GetType() // System.Nullable<int> 应该不等啊,其实System.Nullable<T>中对Equals重载: HasValue属性为 false,并且 other 参数为 空引用。即,根据定义,两个 null 值相等。 - 或 - HasValue 属性为 true,并且 Value 属性返回的值等于 other 参数 所以它们相等 4.对它们转型为Object再判等 object obj1 = i; object obj2 = x; x.Equals(i);//这时结果一定为False 可空类型是 System.Nullable 结构的实例。可空类型可以表示其基础值类型正常范围内的值,再加上一个 null 值。例如,Nullable<Int32>,读作“可空的 Int32”,可以被赋值为 -2147483648 到 2147483647 之间的任意值,也可以被赋值为 null 值。Nullable<bool> 可以被赋值为 true 或 false,或 null。在处理数据库和其他包含可能未赋值的元素的数据类型时,将 null 赋值给数值类型或布尔型的功能特别有用。例如,数据库中的布尔型字段可以存储值 true 或 false,或者,该字段也可以未定义。 可空类型概述 可空类型具有以下特性: 可空类型表示可被赋值为 null 值的值类型变量。无法创建基于引用类型的可空类型。(引用类型已支持 null 值。)。 语法 T? 是 System.Nullable<T> 的简写,此处的 T 为值类型。这两种形式可以互换。 为可空类型赋值与为一般值类型赋值的方法相同,如 int? x = 10; 或 double? d = 4.108;。 如果基础类型的值为 null,请使用 System.Nullable.GetValueOrDefault 属性返回该基础类型所赋的值或默认值,例如 int j = x.GetValueOrDefault(); 请使用 HasValue 和 Value 只读属性测试是否为空和检索值,例如 if(x.HasValue) j = x.Value; 如果此变量包含值,则 HasValue 属性返回 True;或者,如果此变量的值为空,则返回 False。 如果已赋值,则 Value 属性返回该值,否则将引发 System.InvalidOperationException。 可空类型变量的默认值将 HasValue 设置为 false。未定义 Value。 |
相关文章推荐
- 类型“string”必须是不可以为 null 值的类型才能用作泛型类型或方法“System.Nullable<T>”中的参数“T”
- 【基础语言学习】C#中的可空类型运算(Nullable<T>)------T?
- C#读取数据库返回泛型集合 把DataSet类型转换为List<T>泛型集合
- 【C#】对异步请求处理程序IHttpAsyncHandler的理解和分享一个易用性封装 【手记】走近科学之为什么明明实现了IEnumerable<T>的类型却不能调用LINQ扩展方法 【手记】手机网页弹出层后屏蔽底层的滑动响应 【手记】ASP.NET提示“未能创建类型”处理 【Web】一个非常简单的移动web消息框 【手记】解决EXCEL跑SQL遇“查询无法运行或数据库表无法打开...”
- 可空类型"int?" 解决: 【数据库里的int类型可以为null,而在c#里int类型不能为Nul】的问题
- C#读取数据库返回泛型集合 把DataSet类型转换为List<T>泛型集合
- System.Nullable<T> int?
- 使用泛型类型System.Collections.Generic.Icomparer &lt;T&gt; 需要一个类型参数
- nullable数据类型和c#2.0运算符“??”,数据库可能为空时候的一种处理办法
- HashMap<String, Object>中的Object以int类型取出
- List<> 转换为Dataset的C#代码实现 解决Nullable问题
- <<展现C#>>第四章 C#类型(修订)
- C# 数据批量插入到数据库SqlBulkCopy(源数据类型:List<T> Or DataTable)
- 理解null值和C#中可空类型(NullAble<T>)
- 【C#】List<T>类型强制转换
- list<string>转换成list<int>类型
- JAVA POI Excel导出,数据源可以是List<Map>或者List<Model>类型
- C#定义泛型方法错误-类型“T”必须是引用类型才能用作泛型类型或方法“System.Data.Linq.Table<TEntity>”中的参数“TEntity”
- 【C#】 6.Set<T>数据类型
- 工作总结 无法确定条件表达式的类型,因为“<null>”和“System.DateTime”之间没有隐式转换 解决办法 object——Nullable<T> (可空类型)