可空类型"int?" 解决: 【数据库里的int类型可以为null,而在c#里int类型不能为Nul】的问题

来源:互联网 发布:女生铅笔袋淘宝 编辑:程序博客网 时间:2024/05/16 15:15
using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace 可空数据类型{    class Program    {        static void Main(string[] args)        {            string s = null;// c#中string类型的值是可以为NULL的            int i = 123;            //int j = null;// c#中int类型的值是不能为null的。这时候就会报错“无法将Null转换成"int",因为它不是一种不可以为null值的类型”            //***********************既然int类型的值不能为Null。问题来了            //在数据库(SQL)里如果一个字段为int类型 那么它的值是可以为null的 而在C#里 int类型的值不是能为null的假如去数据库里取到一个int类型值为null的数据 赋给 int age。那么age=null显然不合理。因为在c#里int的值不能为null那怎么办呢? 这时候c#中它提供了一种机制,叫可空数据类型 int? 也就是在int后面加一个?号            int? x = 123; //定义一个可空数据类型 变量x,值为123            int? y = null;//定义一个可空数据类型 变量y, 值为null            int a=123;            int? b=5;            b = a; //将一个一定不为空的int类型赋给可能为空的数据类型是可以的            //a = b; //这样会报错”无法将类型"int?"隐式转换为"int"。存在一个显式转换(是否缺少强制转换?)“        }    }}

0 0
原创粉丝点击