在C#和SQL Server数据库中怎么给DateTime类型赋null值、null和""的区别
2010-02-02 14:16
344 查看
今天在将数据库里的datetime类型数据赋给C#里DateTime类型变量的时候遇到一个问题,那就是数据库里面的datetime数据存在null值。
C#默认不能将null赋给DateTime变量,但是可以使用Nullable类型的DateTime,只需在声明变量的时候在DateTime后加一个?号,如:
DateTime? x ;
x便可以赋null值。
但是从数据库的datetime类型变为C#的DateTime类型需要Convert.ToDateTime();如果数据库里面的datetime数据为null的话,这个方法是不能使用的。
于是我加了个if语句:
if((row["date1"])!=null)
但是这个if语句无效,改成
row["date1"].ToString()!=null
仍然无法判断数据库中的datetime类型的列date1是否为null。
后来更改为row["date1"].ToString()!=""终于可以判断了。完整语句为:
DateTime? x;
if(row["date1"].ToString()!="")
x=Convert.ToDateTime(["date1"]);
else
x=null;
注意最后x只能赋null,而不能像原来数据库数据一样赋""。因为x被声明为Nullable<DateTime>类型变量的。
这样,如果将x在存入数据库的话,数据库里显示为1900-1-1.
null和""在C#中的区别是前者没有指向任何String对象,而后者为长度为0的String对象,且为其分配了内存空间。
但是刚刚试了一下,不论""或null存入数据库的时候都是1900-1-1,如果想在数据库里也为null的话,可以选择当x为null或""时,不存入数据库中的相关列。
C#默认不能将null赋给DateTime变量,但是可以使用Nullable类型的DateTime,只需在声明变量的时候在DateTime后加一个?号,如:
DateTime? x ;
x便可以赋null值。
但是从数据库的datetime类型变为C#的DateTime类型需要Convert.ToDateTime();如果数据库里面的datetime数据为null的话,这个方法是不能使用的。
于是我加了个if语句:
if((row["date1"])!=null)
但是这个if语句无效,改成
row["date1"].ToString()!=null
仍然无法判断数据库中的datetime类型的列date1是否为null。
后来更改为row["date1"].ToString()!=""终于可以判断了。完整语句为:
DateTime? x;
if(row["date1"].ToString()!="")
x=Convert.ToDateTime(["date1"]);
else
x=null;
注意最后x只能赋null,而不能像原来数据库数据一样赋""。因为x被声明为Nullable<DateTime>类型变量的。
这样,如果将x在存入数据库的话,数据库里显示为1900-1-1.
null和""在C#中的区别是前者没有指向任何String对象,而后者为长度为0的String对象,且为其分配了内存空间。
但是刚刚试了一下,不论""或null存入数据库的时候都是1900-1-1,如果想在数据库里也为null的话,可以选择当x为null或""时,不存入数据库中的相关列。
相关文章推荐
- 在C#和SQL Server数据库中怎么给DateTime类型赋null值、null和""的区别
- 在C#和SQL Server数据库中怎么给DateTime类型赋null值、null和""的区别
- 在C#和SQL Server数据库中怎么给DateTime类型赋null值、null和
- C#中NULL,"",DBNULL,String.Empty,Convert.IsDBNull()的区别
- C# 中 string.Empty、""、null的区别
- C#中null和""的区别
- C# 设置DateTime类型的变量值等于Null
- asp.net(c#)中String.Empty、NULL、"" 三者到底有啥区别和联系?
- C#中的String.Empty,NULL和""的区别 2010-07-09 17:52:45| 分类: .net | 标签: |字号大中小 订阅 .
- C#中null和""的区别
- c#:无法将 NULL 转换成“System.DateTime”,因为它是一种值类型(转)
- C#中 NULL 、String.Empty 、""的区别
- 可空类型"int?" 解决: 【数据库里的int类型可以为null,而在c#里int类型不能为Nul】的问题
- 转:C#中NULL,"",DBNULL,String.Empty,Convert.IsDBNull()的区别
- c#中datetime类型与SqlServer中datetime格式的区别
- C#中NULL,"",DBNULL,String.Empty,Convert.IsDBNull()的区别
- string类型的""、String.Empty、null三者间的区别
- C#里面""与null的区别;
- C#中NULL,"",DBNULL,String.Empty,Convert.IsDBNull()的区别
- NULL,"",String.Empty三者在C#中的区别