在C#和SQL Server数据库中怎么给DateTime类型赋null值、null和""的区别

摘要:
今天,当我将数据库中的datetime类型数据分配给C#中的datetime类型变量时,遇到了一个问题。也就是说,数据库中的datetime数据具有空值。默认情况下,C#不能为DateTime变量赋值null,但可以使用null类型的DateTime。您只需要添加一个=Null),但if语句无效。将其更改为行[“date1”]ToString()!=Null仍然无法确定数据库中的datetime类型列date1是否为Null。但我只是试过了。当“”或null存储在数据库中时,它是1900-1-1。如果您希望在数据库中为null,可以在x为null或“”时选择不在数据库中存储相关列。
今天在将数据库里的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#和SQL Server数据库中怎么给DateTime类型赋null值、null和""的区别》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇MongoDB 状态监控、备份复制及自动分片局域网中Ubuntu和Windows进行文件夹共享下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

SQL Compare数据库版本比较工具

Red Gate系列文章: Red Gate系列之一 SQL Compare 10.4.8.87 Edition 数据库比较工具 完全破解+使用教程 Red Gate系列之二 SQL Source Control 3.0.13.4214 Edition 数据库版本控制器 完全破解+使用教程 Red Gate系列之三 SQL Server 开发利器 SQL...

在asp.net webform中的 gridview 里面的一些基本操作

<body> <form runat="server"> <table cellspacing="0" cellpadding="0" border="0"> <tr> <td> <asp:Panel runat="server" CssClass="buttonContainer" Wr...

SQL Server在本地计算机上用SSMS(SQL Server Management Studio)登录不上,错误消息:(Microsoft SQL Server, Error: 18456)

今天遇到了一个奇怪的问题,公司目前在SQL Server上都采用AD域账号登录,由于账号人数众多,所以我们建立了一个AD Group(域组),将大家的AD账号加入了这个AD Group,然后我们将这个AD Group设置为了SQL Server的账号。按道理说所有在这个AD Group的AD账号都应该可以用SSMS的Windows认证登录SQL Serve...

文本框根据拼音自动匹配提示

    之前有提到过用jquery来实现文本框的自动匹配(http://hi.baidu.com/yunanwu/item/2a5aa13b1607fa26b3c0c522 ) 发现只能用汉字的匹配,又觉得吧平时在用百度谷歌的时候,输入拼音的时候也可以直接提示,就琢磨着自己实现一下这个功能(发现自己现在看到网页的功能,都要联想着自己去写了)。 关于拼音的...

tp5 使用SMproxy连接池来连接mysql数据库

前言:之前面试的时候被问到tp5-mysql连接池的问题,一下就蒙了,不知道啥玩意,今天有时间特意百度了一下。 PHP连接池的设计初衷是PHP 没有连接池,所以高并发时数据库会出现连接打满的情况,Mycat 等数据库中间件会出现部分 SQL 无法使用,例如不支持批量添加等,而且过于臃肿。 smproxy的原理是将数据库连接作为对象存储在内存中,当用户需要访...

C# 没落了吗?

先上图 ------------------------------------------ C#没落与否跟微软整个平台息息相关。 C#最近几年用的人越来越少,也是因为越来越少的人专门为微软平台开发产品。 基本上,你要开个公司做软件,你如果钱足够的话,一般肯定要做iOS, Android, Web 3个版本,但是是否做Windows版本就不好说了。 现在...