1

我正在将一个 excel 文件上传到服务器,然后将其行和列插入到数据库中。我正在逐行进行,但日期时间有问题。插入 146 行数据后,我收到一条错误消息:

将 varchar 数据类型转换为 datetime 数据类型导致值超出范围。该语句已终止。

问题是它的日期。在 excel 文件中,日期的格式为 dd/mm/yyyy,但数据库将它们视为 mm/dd/yyyy,因此当日期超过 12 日时,我得到超出范围的错误。我不想更改我的 excel 文件,所以有一个选项我可以在数据库(MS SQL 服务器)上更改,还是我必须使用可以在插入它们之前转换它们的 c# 代码......谢谢......

4

5 回答 5

2

如果您知道来自 Excel 的格式,最好使用特定的 IFormatterProvider 将字符串解析为 C# 中的 DateTime。

这里的问题是来自 Excel 的字符串没有文化信息,因此转换为 DateTime 只能考虑数据库的文化 - 在这种情况下是一种反转月份和日期的格式。这将意味着超出范围的日期(如您的情况)或不明确的日期将永远无法正确解析。

在 C# 代码中,您可以指定实现的文化IFormatterProvider,en-GB 具有您指定的 Excel 日期的日期格式。MSDN 文档中的示例显示了如何执行此操作。我的示例简报展示了如何将具有 en-GB 日期格式的字符串转换为与DateTime文化无关的字符串:

var culture = CultureInfo.CreateSpecificCulture("en-GB");
var date = DateTime.Parse("13/12/2011", culture);

SQL 在文化方面也有同样的问题。任何文化敏感数据的字符串表示将始终丢失当前文化。转换该数据时,如果它与服务器不同,则需要指定文化。

您可以在 SQL 中执行此操作,并对您尝试转换的字符串的格式进行硬编码(103 表示 en-GB 日期格式 dd/mm/yyyy):

declare @datestring varchar(10) = '13/12/2011' --13th December
-- 103 is the format code for UK dates with full yyyy century.
select convert(date, @datestring, 103) --gives 2011-12-13

declare @datestring2 varchar(10) = '05/04/2011' --5th April, ambiguous date.
select convert(date, @datestring2, 103) --gives 2011-04-05

转换/转换格式代码。

还值得注意的是,这也将正确转换模棱两可的日期,例如 05/04/2011,如果文化未知,这将反转月/日。

例如,如果您尝试将 2011 年 4 月 5 日的英国日期转换为美国日期而不告诉解析器格式是什么,您将得到 2011 年 5 月 4 日作为输出 - 反转月份和日期。

于 2012-05-24T09:45:42.627 回答
0

您可以在使用 T-SQL 插入之前执行此操作:

set dateformat dmy

请参阅http://msdn.microsoft.com/fr-fr/library/ms189491.aspx

于 2012-05-24T09:47:22.517 回答
0

我认为您必须在 c# 中执行此操作。尝试这样的事情:

String excelDate = ...
String[] dateParts = excelDate.Split('/');
String sqlDate = dateParts[1] + "/" + dateParts[0] + "/" + dateParts[2];
...
于 2012-05-24T09:50:06.360 回答
0

首先将您的 excel datetime 解析为 C# datetime 对象并格式化 datetime 对象,让我们说

DateTime dt = DateTime.Parse(drExcel["dateofExcel"]);
drDB["DateTime"] = dt.ToString("s");

希望它能解决你的问题

于 2012-05-24T09:47:48.023 回答
0

您也可以在数据库中进行操作,也可以尝试编写一个存储过程,使用您的 excelsheet 将数据插入数据库。

下面的用户在您的 SP 中提到了 TSQL 代码,这将起作用。

CREATE PROCEDURE ABC
AS
-- Do some operation
    SET DATEFORMAT ydm;

    insert into @dates
    select '2008-09-01','2008-09-01'

END
于 2012-05-24T09:47:55.260 回答