比如一个实体类对应数据库的一个表,
而且这个表里有日期时间的字段,当数据库里为null时,
那么在实体类里对应的日期是多少?我一般初始化为1900-1-1
大家是怎么做的?

解决方案 »

  1.   

    我的日期一般都是必填字段,学习啊。不知道直接给null成不?
      

  2.   

    但如果是与数据库对应的表DataTable中就可以有空啊,程序如下:private void button1_Click(object sender, EventArgs e)
            {
                DataTable dt = new DataTable();
                dt.Columns.Add(new DataColumn("ID", typeof(string)));
                dt.Columns.Add(new DataColumn("Date", typeof(DateTime)));
                DataRow dr = dt.NewRow();
                dr[0] = "1";
                dt.Rows.Add(dr);
                if (dt.Rows[0][1] == DBNull.Value)
                {
                    MessageBox.Show("空");
                }
            }
      

  3.   

    DateTime是个结构,应该是不能赋null值的楼上说的是DataTable里存的DBNull
      

  4.   

    可以用可空的DateTime类型,用法如下:DateTime? birthday这样这个birthday就可以给它一个null也可以给它一个正常的DateTime值,但其它的值是不行的,和数据库的DateTime是兼容的.
      

  5.   

    表里的日期字段,可以用字符类型。这样处理起来简单很多!
    开发语言都可以把日期字符转换成时间
    -----------------------------------
    这样不太好,当然也是一种处理方法.
    因为DateTime-->字符串--->DateTime这样过程没有必要经过,其实好多ToString()的方法是没有必要使用的.使用了就会增加运算量和占用更多的时间.
    如果有办法不用字符转就不要转.
      

  6.   

    hbxtlhx 所说的  (DateTime?) <----这是一种数据类型?
      

  7.   

    呵呵,Sorry
    我说的是2.0的
    1.1没有这个用法,不好意思.
      

  8.   

    hbxtlhx(平民百姓) 高见,这种的确是C#2.0新特性
      

  9.   

    可空类型是 System.Nullable 结构的实例。可空类型可以表示其基础值类型正常范围内的值,再加上一个 null 值。例如,Nullable<Int32>,读作“可空的 Int32”,可以被赋值为 -2147483648 到 2147483647 之间的任意值,也可以被赋值为 null 值。Nullable<bool> 可以被赋值为 true 或 false,或 null。在处理数据库和其他包含可能未赋值的元素的数据类型时,将 null 赋值给数值类型或布尔型的功能特别有用。例如,数据库中的布尔型字段可以存储值 true 或 false,或者,该字段也可以未定义。
      

  10.   

    可空类型具有以下特性:可空类型表示可被赋值为 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。使用 ?? 运算符分配默认值,当前值为空的可空类型被赋值给非空类型时将应用该默认值,如 int? x = null; int y = x ?? -1;。不允许使用嵌套的可空类型。将不编译下面一行:Nullable<Nullable<int>> n;
      

  11.   

    原来用2.0之前像楼主这种问题我一般是这样来做的:
    1:用object来代替DateTime类型,这样相当于装箱,如果数据库为DBNull.Value也不会有问题.
    这个做法最好的就是可以使用在DateTimePicker上,因为这个控件有一个ShowCheckBox属性,如果这个Object的值不是DateTime则CheckBox为不选上,DateTimePicker不可用.这个正好.2:就一个标志来表示一个DateTime的属性是否有效,比如果用set这个属性方法设置过有效的DateTime值,那么就会有一个标志比如dirty,这个dirty为Boolean类型,则我设置为true,表示有正确的值,如果设置的值不正确或没有设置过值,则这个dirty为false,那么在存到数据库的时候就用DBNull.Value来存了.
      

  12.   

    谢谢 hbxtlhx(平民百姓) 指教落后了,看来我得转到2.0了 
      

  13.   

    C#的DateTime.MinValue与SQL的最小值 不一致
      

  14.   

    只是用它来判断是不是空嘛
    如果字段是它 那就插DB.NULL喽 我才不关心它得啥