[英]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.