转换日期时间

时间:2012-03-12 13:47:20

标签: c#

我想转换日期时间。我不知道怎么做?它给出了错误。 nvarchar不会转换为datetime。

startDate格式:“11.03.2012”

我的桌子: STARTDATE日期时间 ENDDATE datetime

public static int Insert(string startDate, string endDate)
{

    Conn c = new Conn();
    SqlParameter[] prms = new SqlParameter[]{
    new SqlParameter("@STARTDATE", DateTime.ParseExact(startDate,"DD MM YYYY",null)),
    new SqlParameter("@ENDDATE",  DateTime.ParseExact(endDate,"DD MM YYYY",null)),        
    };

    return Convert.ToInt32(c.getObjectSP("sp_Insert", prms));
}

2 个答案:

答案 0 :(得分:3)

如果日期格式为"11.03.2012",则需要在格式字符串中使用 .解析

DateTime.ParseExact(startDate,"dd.MM.yyyy",null)

另请注意,DDYYYY不是字符,这些字符在格式字符串中标识为数据时间的一部分,但应该是文字。请参阅我的示例 - dd表示天数为2个字符,yyyy表示年份为4个字符。

答案 1 :(得分:2)

这是一篇很好的文章: http://www.csharp-examples.net/string-format-datetime/

// create date time 2008-03-09 16:05:07.123
DateTime dt = new DateTime(2008, 3, 9, 16, 5, 7, 123);

String.Format("{0:y yy yyy yyyy}", dt);  // "8 08 008 2008"   year
String.Format("{0:M MM MMM MMMM}", dt);  // "3 03 Mar March"  month
String.Format("{0:d dd ddd dddd}", dt);  // "9 09 Sun Sunday" day
String.Format("{0:h hh H HH}",     dt);  // "4 04 16 16"      hour 12/24
String.Format("{0:m mm}",          dt);  // "5 05"            minute
String.Format("{0:s ss}",          dt);  // "7 07"            second
String.Format("{0:f ff fff ffff}", dt);  // "1 12 123 1230"   sec.fraction
String.Format("{0:F FF FFF FFFF}", dt);  // "1 12 123 123"    without zeroes
String.Format("{0:t tt}",          dt);  // "P PM"            A.M. or P.M.
String.Format("{0:z zz zzz}",      dt);  // "-6 -06 -06:00"   time zone