c# SqlException: 从 datetime2 数据类型到 datetime 数据类型的转换产生一个超出范围的值

79 篇文章 11 订阅

环境:

  • window 10 x64
  • vs2019
  • .net core 3.1
  • efcore 3.1.9
  • sqlserver 2008r2

原因:
0000:01:01 00:00:00插入到datetime类型溢出了,因为datetime的范围是0001-01-019999-12-31!!!

一、sqlserver支持的日期时间类型(全)

参照:https://docs.microsoft.com/zh-cn/sql/t-sql/data-types/date-and-time-types?view=sql-server-ver15
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

二、出错原因

当定义如下表时:

create table test(
	id int primary key,
	createdate datetime
)

如果我们执行下面语句:

insert into test(id,createdate) values(1,'0000-01-01 00:00:00');

name将会得到如下错误:
在这里插入图片描述

三、使用efcore快速复现

还是用上面那张表,新建.net core控制台工程TestDateTimeBug
引入包Microsoft.EntityFrameworkCore.SqlServer

<ItemGroup>
  <PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="3.1.9" />
</ItemGroup>

配置DBContext和实体类,新建文件TestDbContext.cs,代码如下:

using Microsoft.EntityFrameworkCore;
using System;
using System.ComponentModel.DataAnnotations.Schema;

namespace TestDateTimeBug
{
    public class TestDbContext : DbContext
    {
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            if (!optionsBuilder.IsConfigured)
            {
                optionsBuilder.UseSqlServer("Data Source=.;Initial Catalog=test;User Id=sa;Password=123456");
            }
        }
        public DbSet<Test> Tests { set; get; }
    }

    [Table("test")]
    public class Test
    {
        public int Id { get; set; }
        public DateTime CreateDate { get; set; }
    }
}

此时,在Program.cs中书写插入代码:

using System;

namespace TestDateTimeBug
{
    class Program
    {
        static void Main(string[] args)
        {
            using (var db = new TestDbContext())
            {
                var test = new Test()
                {
                    Id = 1
                };
                db.Tests.Add(test);
                db.SaveChanges();
            };
            Console.WriteLine("Hello World!");
        }
    }
}

当运行后发现报错:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jackletter

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值