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

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"。存在一个显式转换(是否缺少强制转换?)“

        }
    }
}

你可能感兴趣的:(ADO.NET,SQL,Server)