首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >DateTime.MinValue和SqlDateTime溢出

DateTime.MinValue和SqlDateTime溢出
EN

Stack Overflow用户
提问于 2013-03-01 12:04:15
回答 10查看 167.9K关注 0票数 74

我不想验证txtBirthDate,所以我想在数据库中传递DateTime.MinValue

我的代码:

代码语言:javascript
复制
 if (txtBirthDate.Text == string.Empty)
    objinfo.BirthDate = DateTime.MinValue;
 else
     objinfo.BirthDate =  DateTime.Parse(txtBirthDate.Text);

DateTime.MinValue返回Date = {1/1/0001 12:00:00 AM}

我得到了一个SQL错误:

SqlDateTime溢出必须在1/1/1753 12:00上午12:00至12/31/9999 11:59:59下午

我坚持住了,但我不明白为什么DateTime.MinValue返回无效的日期时间,无法在database.How中插入来处理这种情况?

EN

回答 10

Stack Overflow用户

回答已采纳

发布于 2013-03-01 12:06:34

基本上,不要使用DateTime.MinValue来表示缺少的值。您不能在Server DateTime.MinValue字段中使用DateTime,因为Server的最小值为1753开始。

相反,将BirthDate属性设置为Nullable<DateTime> (也称为DateTime?),并在没有值时将其设置为null。还要确保您的数据库字段是可空的。然后,您只需要确保null最终成为数据库中的NULL值。您是如何做到这一点的,这将取决于您的数据访问,而您还没有告诉我们任何关于数据的访问。

票数 100
EN

Stack Overflow用户

发布于 2013-03-01 12:26:55

非常简单,避免使用DateTime.MinValue,而是使用System.Data.SqlTypes.SqlDateTime.MinValue

票数 118
EN

Stack Overflow用户

发布于 2016-10-03 14:48:02

好吧..。获取SQL min日期非常简单。

代码语言:javascript
复制
DateTime sqlMinDateAsNetDateTime = System.Data.SqlTypes.SqlDateTime.MinValue.Value;
票数 15
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15157328

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档