[英]DateTime.ParseExact is not doing what i want it to do
当对DateTime使用.ParseExact()方法时,我总是得到与我输入的字符串相同的输出。这是我的代码:
[Authorize(Roles = "Backoffice, Manager")]
[HttpPost]
public ActionResult FilmShowCreate(FilmShowViewModel newFilmShow)
{
if (ModelState.IsValidField("FilmId") && ModelState.IsValidField("Time"))
{
DateTime unformattedDateTime = newFilmShow.Date.Date + newFilmShow.Time.TimeOfDay;
string dateString = unformattedDateTime.ToString("yyyy-MM-dd HH:mm:ss");
DateTime dbDate = DateTime.ParseExact(dateString, "yyyy-MM-dd HH:mm:ss",
CultureInfo.GetCultureInfo("en-US"), DateTimeStyles.AdjustToUniversal);
FilmShow filmShow = new FilmShow
{
Film = filmRepository.GetFilm(newFilmShow.FilmId),
Cinema = cinemaRepository.GetCinema(newFilmShow.CinemaId),
ThreeDimensional = newFilmShow.ThreeDimensional,
Date = dbDate,
SpecialEvent = newFilmShow.SpecialEvent
};
filmShowsRepository.AddShow(filmShow);
return View("SuccesfullFilmShowCreate");
字符串dateString格式正常,但它是一个字符串,我需要将其作为格式DateTime存储在数据库中,如“year-month-day hours:minutes:seconds”。 但无论出于何种原因,ParseExact在我的情况下似乎不起作用。 我得到的DateTime格式是“dd-MM-yyyy HH:mm”。
它不会做你想要的,因为,那个功能不应该做你所描述的。
ParseExact
只是表明输入必须与给定的格式匹配才能被使用(而不是抛出异常)。 它与Parse
相对应,它将接受任何有效的日期/时间格式。 它绝对不会影响它创建的DateTime
对象的任何字符串表示的未来格式。
如果要以给定格式输出它,请在将该字符串发送到数据库之前将格式字符串传递给ToString
。 当然,如果您使用的是EF,那么转换就是为您完成的,并不重要。
例:
string myFormattedDateTime = dbDate.ToString("yyyy-MM-dd HH:mm:ss");
更仔细地阅读你的问题,我意识到你似乎认为DateTime有一些“存储”格式。 它不是。 DateTime只是一组数字,包含表示日期和时间所需的信息。 你所描述的格式只存在于字符串表示。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.